1

我的输入文件如下所示,我需要根据分隔符“~”对这个文件进行排序,即第 1 列按升序排列,第 5 列按降序排列。

010001~01001~JAN-00~009901~1~  
010001~01001~JAN-00~009901~2~  
010001~01001~JAN-00~009901~W~  
010001~01001~JAN-00~009901~X~  
010001~01001~JAN-00~009901~Z~  
010001~01001~JAN-00~009901~i~  
010001~01001~JAN-00~009901~j~  
010001~01001~JAN-00~009901~m~  
010001~01001~JAN-00~009901~n~  
010001~01001~JAN-00~009901~o~  
010001~01001~JAN-00~009901~p~  
010001~01001~JAN-00~009901~q~  
200407~20043~JUL-04~200307~P~  
200407~20043~JUL-04~200307~V~  
200407~20043~JUL-04~200307~k~  
200408~20043~AUG-04~200308~P~  
200408~20043~AUG-04~200308~V~  
200408~20043~AUG-04~200308~k~  
200409~20043~SEP-04~200309~P~  
200409~20043~SEP-04~200309~V~  
200409~20043~SEP-04~200309~k~  
200410~20044~OCT-04~200310~P~  
200410~20044~OCT-04~200310~V~  
200410~20044~OCT-04~200310~k~  
200411~20044~NOV-04~200311~P~  
200411~20044~NOV-04~200311~V~  
200411~20044~NOV-04~200311~k~  
200412~20044~DEC-04~200312~P~  
200412~20044~DEC-04~200312~V~  
200412~20044~DEC-04~200312~k~  

我尝试了以下命令,但无法获得所需的结果

sort -t$'~' -k1 -k5r filename

我生成的文件应该匹配如下

010001~01001~JAN-00~009901~q~  
010001~01001~JAN-00~009901~p~  
010001~01001~JAN-00~009901~o~  
010001~01001~JAN-00~009901~n~  
010001~01001~JAN-00~009901~m~  
010001~01001~JAN-00~009901~j~  
010001~01001~JAN-00~009901~i~  
010001~01001~JAN-00~009901~Z~  
010001~01001~JAN-00~009901~X~  
010001~01001~JAN-00~009901~W~  
010001~01001~JAN-00~009901~2~  
010001~01001~JAN-00~009901~1~  
200407~20043~JUL-04~200307~k~  
200407~20043~JUL-04~200307~V~  
200407~20043~JUL-04~200307~P~  
200408~20043~AUG-04~200308~k~  
200408~20043~AUG-04~200308~V~  
200408~20043~AUG-04~200308~P~  
200409~20043~SEP-04~200309~k~  
200409~20043~SEP-04~200309~V~  
200409~20043~SEP-04~200309~P~  
200410~20044~OCT-04~200310~k~  
200410~20044~OCT-04~200310~V~  
200410~20044~OCT-04~200310~P~  
200411~20044~NOV-04~200311~k~  
200411~20044~NOV-04~200311~V~  
200411~20044~NOV-04~200311~P~  
200412~20044~DEC-04~200312~k~  
200412~20044~DEC-04~200312~V~  
200412~20044~DEC-04~200312~P~  

有人可以帮我解决这个问题。

4

1 回答 1

3

告诉sort 哪里停止匹配以及从哪里开始。

sort -t$'~' -k1,1 -k5,5r filename

如果没有,1(and ,5),第一个比较从第 1 列运行到行尾。

POSIX 说:

符号:

-k field_start[type][,field_end[type]]

应定义一个从包含开始field_start和结束的关键字段field_end,除非field_start超出行尾或在 之后field_end,在这种情况下,关键字段为空。缺失field_end应表示该行的最后一个字符。

于 2013-09-10T16:29:53.567 回答