Linux下如何对内容去重,用什么命令
Admin 2022-07-26 群英技术资讯 443 次浏览
大家可能经常遇到文件内容排序去重处理的事情,使用 linux 命令可以很方便的处理,sort 命令在处理文件排序和去重中起着非常重要的左右,是文件处理的利器。
比如有以下文件内容:
pythontab.com
4345 15 12121 4145 7 fdf 4245 5 dfsf 1345 76 432423 0693 2 4345 06a7 82 4e 06a9 58 e33 4345 68 343 06c1 56 453 06d7 145 45678 4345 117 21 06e3 280 76 4345 7 3434 4345 48 80 06f1 463 121 4345 3847 131 070b 1236 64 070d 3343 77 0713 104235 90 0715 6 12 0726 121 97798
想要按照第二列排序去重,怎么做呢?其实只需要 sort 命令就可以解决了
sort -t $'\t' -k 2 -u pythontab.com
sort 排序命令
-t 指定分隔符为‘\t’
-k 指定第三列
-u 去重
sort的其他一些选项:
-r 降序排列
-o 把排序结果输出到源文件
sort默认是把结果输出到标准输出,所以需要用重定向才能将结果写入文件,形如
sort filename>newfile
如果将结果输出到原文件,用重定向相当于清空
-n 看为数字来比较
你有没有遇到过10比2小的情况。我反正遇到过。出现这种情况是由于排序程序将这些数字按字符来排序了,排序程序会先比较1和2,显然1小,所以就将10放在2前面喽。这也是sort的一贯作风。
我们如果想改变这种现状,就要使用-n选项,来告诉sort,“要以数值来排序”!
-f 会将小写字母都转换为大写字母来进行比较,亦即忽略大小写
-c 会检查文件是否已排好序,如果乱序,则输出第一个乱序的行的相关信息,最后返回1
-C 会检查文件是否已排好序,如果乱序,不输出内容,仅返回1
-M 会以月份来排序,比如JAN小于FEB等等
-b 会忽略每一行前面的所有空白部分,从第一个可见字符开始比较。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
集线器工作在物理层,所以它比较笨,不能识别MAC帧。傻瓜式操作,将一个端口收到的所有字节都复制到其他端口,所以它会有性能问题。
在linux中,package指的是包,也即应用程序,也可以是GUI应用程序、命令行工具或者软件库;package本质上是一个存档文件,其中包含二进制可执行文件、配置文件,还会包含有关依赖项的信息。
linux删除文件名是乱码文件的方法:1、利用“ls -i”命令获取文件的节点号,ls命令用于显示指定工作目录下之内容;2、通过获取到的文件节点号利用find命令即可删除指定的文件,语法为“find -inum 节点号 -delete”。
linux文件目录命令有:1、ls,用于列出目录及文件名;2、cd,用于切换目录;3、pwd,用于显示目前的目录;4、mkdir,用于创建新目录;5、rmdir,用于删除空目录;6、cp,用于复制文件或目录;7、rm,用于删除文件或目录等。
linux中ipv6是能关闭的。关闭方法:1、利用vi编辑器打开“/etc/modprobe.conf”文件;2、在文档中添加“alias net-pf-10 off”和“alias ipv6 off”,保存退出后,重新启动系统即可。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008