簡體   English   中英

用數字順序對制表符分隔文件中的行進行排序

[英]Sort rows in a tab delimited file with numerical order

我正在嘗試對以下格式的文件進行排序

ch1 1 209
ch1 23 890
ch3 45 21
ch4 66 12
ch10 12 90
ch10 11 53

我正在使用命令

sort -t $"\t" -nk1 filename

但是結果是ch1在ch10之后

ch10 12 90
ch10 11 53
ch1 1 209
ch1 23 890
ch3 45 21
ch4 66 12

但是我希望數值在1之前排在10之前。 那么有人可以建議需要做什么嗎? 預期結果:

ch1 1 209
ch1 23 890
ch3 45 21
ch4 66 12
ch10 12 90
ch10 11 53

KEYDEF的字段中指定數字開頭的字符索引。 在這種情況下,我們要對第一個字段的數字部分(從第三個字符開始)進行排序,即-k1.3n

$ sort -k1.3n file
ch1     1       209
ch1     23      890
ch3     45      21
ch4     66      12
ch10    11      53
ch10    12      90

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM