我的输入文件如下所示,我需要根据分隔符"~"对该文件进行排序,即第 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~
有人可以帮助我解决这个问题吗?
告诉sort
在哪里停止匹配以及从哪里开始。
sort -t$'~' -k1,1 -k5,5r filename
如果没有,1
(和,5
),第一次比较从第 1 列开始到行尾。
波西克斯 说:
表示法:
-k field_start[type][,field_end[type]]
应定义一个从
field_start
开始并在field_end
(含)结束的键字段,除非field_start
超出行尾或field_end
之后,在这种情况下,键字段为空。缺少field_end
应表示该行的最后一个字符。