Chinaunix

标题: 关于IP地址排序 [打印本页]

作者: bikkuri    时间: 2023-03-11 10:42
标题: 关于IP地址排序
大家好!
我有一个问题向大家请教。
有这样一个文本,包含了一些IP地址。
[root@linux:/tmp]# cat a
192.168.12.49
192.168.12.5
192.168.12.50
192.168.140.49
192.168.140.5
192.168.140.50
我想对这些地址先对网段排序,即192.168.12网段在192.168.140网段前面,然后每个网段里的IP按自然数排序,即5,49,50的顺序。
排出来的顺序应该是
192.168.12.5
192.168.12.49
192.168.12.50
192.168.140.5
192.168.140.49
192.168.140.50
可是我试了很多排序命令都排不出来这样的顺序。
[root@linux:/tmp]# cat a|sort -t "." -k4n
192.168.12.5
192.168.140.5
192.168.12.49
192.168.140.49
192.168.12.50
192.168.140.50
[root@linux:/tmp]# cat a|sort -t "." -k3 -k4n
192.168.12.49
192.168.12.5
192.168.12.50
192.168.140.49
192.168.140.5
192.168.140.50
[root@linux:/tmp]#
请问应该如何才能排出期望的顺序呢?应该不需要用awk吧?



作者: bikkuri    时间: 2023-03-11 19:51
本帖最后由 bikkuri 于 2023-03-12 07:54 编辑

[root@linux:/tmp]# cat a|awk '{split($1,i,".");n=((i[1]*256+i[2])*256+i[3])*256+i[4];a[n]=$0}END{for(j=1;j<=asorti(a,b);j++)print a[b[j]]}'
192.168.12.5
192.168.12.49
192.168.12.50
192.168.140.5
192.168.140.49
192.168.140.50
[root@linux:/tmp]#

作者: 本友会机友会摄友会    时间: 2023-03-12 16:47
提示: 作者被禁止或删除 内容自动屏蔽
作者: bikkuri    时间: 2023-03-13 08:20
[root@linux:/tmp]# cat a|awk '{split($1,i,".");n=((i[1]*256+i[2])*256+i[3])*256+i[4];a[n]=$0}END{slen=asorti(a,b);for(j=1;j<=slen;j++)print a[b[j]]}'
192.168.12.5
192.168.12.49
192.168.12.50
192.168.140.5
192.168.140.49
192.168.140.50
[root@linux:/tmp]#
作者: baby_神    时间: 2023-03-13 11:26
直接上 sort
  1. [root@test-02 ~]# cat a
  2. 192.168.12.49
  3. 192.168.12.5
  4. 192.168.12.50
  5. 192.168.140.49
  6. 192.168.140.5
  7. 192.168.140.50
  8. [root@test-02 ~]# sort -t "." -k 1n,1 -k 2n,2 -k 3n,3 -k 4n,4 a
  9. 192.168.12.5
  10. 192.168.12.49
  11. 192.168.12.50
  12. 192.168.140.5
  13. 192.168.140.49
  14. 192.168.140.50
复制代码

作者: legs    时间: 2023-03-13 17:09
sort足矣,只是很多人忽略了用法:
  1. sort -nt.  -k3,3 -k4,4 a
复制代码

作者: bikkuri    时间: 2023-03-16 10:39
非常感谢!学习了!
作者: wh7211    时间: 2023-05-19 15:48
回复 1# bikkuri


  1. sort -V a
复制代码

作者: bikkuri    时间: 2023-05-23 15:31
哇!这是什么功能?一个-V直接就搞定了啊?
       -V, --version-sort
              natural sort of (version) numbers within text

回复 8# wh7211



作者: Shell_HAT    时间: 2023-07-26 17:26
回复 1# bikkuri


可是我试了很多排序命令都排不出来这样的顺序。

原因请参考:
http://bbs.chinaunix.net/thread-1773591-1-1.html#pid12746716
作者: ylfind    时间: 2023-08-03 14:21
回复 8# wh7211

绝了,真的妙哇,到处是隐藏的知识点。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2