排序命令: sort,uniq,wc

6 篇文章 0 订阅

介绍好用的排序与统计指令。

  • sort
  • uniq
  • wc

sort

sort可以帮我们进行排序,而且可以依据不同的数据型态来排序。例如数字与文字排序不一样。此外,排序的字符与语系的编码有关,因此,如果需要排序,建议使用LANG=C来让语系统一,数据排序比较好一些。

$ sort [-fbMnrtuk][file or stdin]
选项与参数:
-f:忽略大小写差异;
-b:忽略最前面的空格符部分;
-M:以月份的名字来排序,例如JAN,DEC等排序方法;
-n:使用【纯数字】进行排序(默认以文字型态排序);
-r:反向排序;
-u:就是uniq,相同的数据,仅出现一行代表;
-t:分隔符,预设【tab】键来分隔;
-k:以哪个区间进行排序。

example1:将/etc/passwd下账号进行排序。
debian@debian-pc:~$ cat /etc/passwd | sort
_apt:x:104:65534::/nonexistent:/bin/false
avahi:x:111:122:Avahi mDNS daemon,,,:/var/run/avahi-daemon:/bin/false
backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
debian:x:1000:1000::/home/debian:/bin/bash
deepin-daemon:x:110:121::/home/deepin-daemon:/bin/false
#sort预设【以第一个】数据开排序,且默认以【文字】型态排序,由a排到最后。

example2:/etc/passwd内容以:来分隔,以第三栏排序。
debian@debian-pc:~$ cat /etc/passwd | sort -t ':' -k 3
root:x:0:0:root:/root:/bin/bash
debian:x:1000:1000::/home/debian:/bin/bash
systemd-timesync:x:100:102:systemd Time Synchronization,,,:/run/systemd:/bin/false
uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin
systemd-network:x:101:103:systemd Network Management,,,:/run/systemd/netif:/bin/false
systemd-resolve:x:102:104:systemd Resolver,,,:/run/systemd/resolve:/bin/false
systemd-bus-proxy:x:103:105:systemd Bus Proxy,,,:/run/systemd:/bin/false
_apt:x:104:65534::/nonexistent:/bin/false
messagebus:x:105:109::/var/run/dbus:/bin/false
pulse:x:106:114:PulseAudio daemon,,,:/var/run/pulse:/bin/false

uniq

如果排序完成了,想要将重复的资料仅列出一个显示,可以怎么做?

uniq [-ic]
选项与参数:
-i:忽略大小写;
-c:进行计数

example1:
使用last将账号列出,仅取出账号栏,进行排序后仅取出一位。
debian@debian-pc:~$ last | cut -d ' ' -f1 |sort |uniq

example2:
承上题,如果想知道每个人的登录次数?
debian@debian-pc:~$ last | cut -d ' ' -f1 |sort |uniq -c

wc

如果想知道/etc/man.config 这个文档里面有多少字?多少行?多少字符,就可以用wc这个指令。

wc [-lwm]
选项与参数:
-l:仅列出多少行;
-w:仅列出多少字(英文单字);
-m:多少字符。

example1:
那个/etc/man.config里面有多少行、字、字符数?
debian@debian-pc:~$ cat /etc/manpath.config | wc
    131     714    5170
#输出三个数字,分别代表:行、字符、字数、字符数

example2:
使用last输出登录者,但是last最后两行并非账号内容,该如何以一行指令串取得这个月登录系统的总人次?
debian@debian-pc:~$ last | grep [a-zA-Z] | grep -v ''wtmp | wc -l
4
#由于last输出空白行及wtmp字样在最底下,因此,使用grep取出非空白行及去除wtmp那一行。
### 回答1: sort命令用于对文件进行排序,可以按照字母、数字等方式排序uniq命令用于去除文件中的重复行,可以用于统计文件中不同行的数量。 wc命令用于统计文件中的行数、单词数和字符数等信息,可以用于分析文件的内容。 ### 回答2: Linux sort命令是用来对文本文件进行排序命令。它可以按照不同的排序规则,包括字母顺序、数字顺序、日期顺序等对文件进行排序sort命令默认按照字母顺序进行排序,但可以使用参数来改变排序规则。sort命令可以从命令行或者文件中读取输入,然后将排序结果输出到标准输出或者文件中。 Linux uniq命令用于去除文件中的重复行。uniq命令默认情况下只能去除相邻的重复行,如果想要去除非相邻的重复行,需要先使用sort命令将文件进行排序,然后再使用uniq命令uniq命令可以从命令行或者文件中读取输入,并将去除重复行的结果输出到标准输出或者文件中。 Linux wc命令用于统计文件中的行数、字数和字符数。wc命令可以从命令行或者文件中读取输入,并将统计结果输出到标准输出或者文件中。wc命令默认情况下会输出一个包括行数、字数和字符数的行。可以使用参数来改变输出格式,如只输出行数、只输出字数、只输出字符数等。wc命令在处理大文件时非常高效。 以上是对Linux sortuniqwc命令的简要介绍。这些命令在Linux系统中非常有用,可以帮助我们对文件进行排序、去除重复行和统计信息。它们具有丰富的参数选项,可以根据不同的需求进行灵活的使用。 ### 回答3: Linux中的sort命令是用来排序文本文件内容的命令,它能够按照字母顺序对每一行进行排序sort命令的一般语法为:sort [选项] [文件名]。 -sort命令的一些常用选项有: -n,按照数值进行排序; -r,按照逆序进行排序; -u,去除重复的行; -k n,按照指定的列进行排序,n为列号; -o,将排序结果输出到指定的文件。 uniq命令用于去除文本文件中相邻的重复行。它能够检测和去除由sort命令排序之后的重复行。uniq命令的一般语法为:uniq [选项] [文件名]。 -uniq命令的一些常用选项有: -c,显示每行出现的次数; -d,仅显示重复的行; -u,仅显示没有重复的行; -i,忽略大小写。 wc命令用于统计文件中的行数、字数和字节数。wc命令的一般语法为:wc [选项] [文件名]。 -wc命令的一些常用选项有: -l,仅统计行数; -w,仅统计字数; -c,仅统计字节数; -m,统计字符数,包括空格。 这三个命令在Linux中广泛应用于文本文件的处理和统计工作。通过组合使用这些命令,我们可以实现对文本文件的排序、去重和统计工作,提高工作效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值