- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
编者注:问题的原始标题提到了制表符作为字段分隔符。
在诸如
的文本中500 east 23rd avenue Toronto 2 890 400000 1
900 west yellovillage blvd Mississauga 3 800 600090 3
您将如何按倒数第二列的升序排序?
编者注:OP 后来提供了另一个示例输入行,500 Jackson Blvd Toronto 3 700 40000 2
,其中仅包含 8 个空格分隔的输入字段(与上面的 9 相比),表明需要处理输入中可变数量的字段。
最佳答案
注意:有几个可能独立的问题:
更新:问题C是相关问题。
问题 A:正如问题标题仅所暗示的:如何使用制表符 (\t
) 作为字段分隔符?
问题 B:在给定固定数字的情况下,如何在不知道该字段的特定索引的情况下按倒数第二个字段对输入进行排序字段数?
问题 C:在给定一个变量数字的情况下,如何在不知道该字段各自索引的情况下按倒数第二个字段对输入进行排序字段数?
问题 A 的答案:
sort
的 -t
选项允许您指定字段分隔符。默认情况下,sort
使用任何一行内部空白作为分隔符。
假设使用 Bash、Ksh 或 Zsh,您可以使用 ANSI C-quoted string ($'...'
) 将单个制表符指定为字段分隔符 ($'\t'
):
sort -t $'\t' -n -k8,8 file # -n sorts numerically; omit for lexical sorting
问题 B 的答案:
注意:这假定所有输入行都具有相同 个字段,并且输入来自文件 file
:
# Determine the index of the next-to-last column, based on the first
# line, using Awk:
nextToLastColNdx=$(head -n 1 file | awk -F '\t' '{ print NF - 1 }')
# Sort numerically by the next-to-last column (omit -n to sort lexically):
sort -t $'\t' -n -k$nextToLastColNdx,$nextToLastColNdx file
注意:要按单个 字段排序,也始终将其指定为结束 字段(例如,-k8,8
),如上所述,因为 sort
,仅给定一个 start 字段索引(例如,-k8
),从指定字段排序到该行的其余部分。
问题 C 的答案:
注意:这假定输入行可能具有可变 数量的字段,并且在每一行上该行的倒数第二个字段应该起作用作为排序字段;输入来自文件 file
:
awk '{ printf "%s\t%s\n", $(NF-1), $0 }' file |
sort -n -k1,1 | # omit -n to perform lexical sorting
cut -f2-
awk
命令提取每一行的倒数第二个字段,并将其添加到输出的输入行,以制表符分隔。cut
再次删除人为前置的排序字段。关于linux - 如何按倒数第二个字段对具有可变数量字段的输入进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34124204/
如果我有一个变量 8589934592 示例: var a = (8589934592 | 0); //a is 0 var b = (8589934591223 | 0); //b
随着我们提高音阶,音符频率增加; #define A4 440 // These are the frequencies of the notes in herts #define A
我有一个这样组织的列表: [('down', 0.0098000000000000309), ('up', 0.0015000000000000568), ('down', 0.00890000000
如果我有一个多项式 P,有没有办法计算 P^-1 模 Q,即 Q 是另一个多项式?我知道这两个多项式的系数都属于以 z 为模的整数域,即 z 是一个整数。 我不确定 SymPy 是否已经在其 galo
对于给定的文件,我可以向后计算行数吗?即从 EOF 开始,计算行数直到开始? 我可以 fseek 到文件末尾。从那里开始,继续寻找新行字符(新行的指示)并继续增加我的 line_number 计数。但
有什么方法可以编写带除法的 C 代码来命令编译器在代码中需要常规除法精度的几个特定位置不使用快速除法(通过倒数数学),即使在全局允许倒数数学的情况下也是如此? 理想情况下,有一种方法不是特定于编译器的
我正在尝试将照片从我计算机上的本地文件导入到我的 HTML 文件中。我已经设法做到了,但它是按升序排列的。我尝试添加一个变量 JavaScript $(document).ready( functio
我正在尝试使用 commons-math 计算 2 尾学生分布的逆。我正在使用 Excel 来比较值并验证结果是否正确。 所以使用excel计算TINV,自由度为5,我使用95.45% =TINV(0
我有一个 jQuery 相机插件,它使用以下命令来拍摄快照。 这是它运行的代码。 function take_snapshot() { // take snapshot and get i
我刚刚学会了训练 brain.js network 并且只是在玩它。然后我很好奇是否可以采取相反的方式 - 从输出预测输入? 这是我的代码 const brain = require('brain.j
如果精度不重要,有什么方法可以提高速度的倒数(X 的除法 1)? 所以,我需要计算 1/X。是否有一些解决方法让我失去精度但做得更快? 最佳答案 𝗛𝗲𝗿𝗲𝗛𝗲𝗿𝗲𝗛𝗼𝘄𝗧𝗼?
令 N 为整数。如果N = 2536,则反转N为6352。如果N = 1000000,则反转N为1。 给定一个整数 M,其中 1 <= M <= 10^(100000)。 我们需要找到一个整数 N 是
我是一名优秀的程序员,十分优秀!