Linux管道命令
linux,数据2016-08-12
管道命令能够将一个命令的执行结果经过筛选,只保留我们需要的信息。
如,/etc目录下会有大量的文件,如果使用ls很难找到需要的文件,因此可以使用管道命令将ls的结果进行一次筛选,只保留需要的信息。
cut为剪切的意思,它能将一行行的数据按照指定的分隔符切成一列列,然后只显示特定列的数据。
cut有两种使用方式:
cut -d '分隔符' -f n
例子:显示环境变量PATH第1和6列的数据
echo $PATH | cut -d ':' -f 1,6
cut -c 起始字符的下标-结束字符的下标
注意:cut中涉及的下标均从1开始。
grep用于进行关键词查找,它会将文件中含有关键词的那一整行输出来。
grep [-cinv] [--color=auto] '关键词' 待查找的文件名
-c:统计关键词出现的次数
-i:关键词忽略大小写
-n:输出行号
-v:反向选择,即查找不包含该关键词的行
--color=auto:关键词高亮
这种方式并没有用到管道,只是从指定文件中将符合关键词的行搜索出来。
这种方式采用管道,将前一个命令的执行结果输出给grep,并通过grep的关键词搜索将符合条件的行搜索出来。
sort命令能够将指定文件 或 前一个命令的结果数据 按照指定字段进行排序。
sort [-参数] 文件
-t:指定分隔符
-k:选取分隔后的第几个字段进行排序
-f:排序时忽略选取字段的大小写
-b:去除选取字段前的空格
-M:将选取的字段按照月份来排序(前提是选取字段就是月份)
-n:将选取字段按照数据来排序(前提是选取字段就是数字)
-r:反向排序
-u:去重。若选取字段有重复,则去掉重复。
和grep一样,sort也有两种使用方式。
将文件中的数据按照指定字段排序。
使用管道,将前一个命令执行的结果按照指定字段进行排序。
uniq命令只能用于管道,它能够去除前一个命令执行的结果中完全一样的行。
uniq [-参数]
-i:忽略大小写
-c:进行重复行的统计
该命令只能用于管道,如统计当前系统所有用户的登录次数:
last | cut -d ' ' -f 1 | uniq -c
wc [-参数]
-l:列出行数
-w:列出字数
-m:列出字符数
wc只能通过管道使用:命令 | wc [-参数]
tee能够同时将命令执行的结果输出到指定的文件和屏幕。
tee [-a] 文件
-a:以追加的形式写入文件。
tee只能和管道结合使用,如将last中的信息输出指文件并显示在屏幕上:
last | tee -a lastfile | cut -d ' ' f 1
last的所有信息将会被写入文件lastfile中,然后数据流将会输出到屏幕上,我们可以在输出前再添加一条管道,只输出数据的第一个字段。
这个命令与管道无关。
它相当于数据库中的join连接,将两张表中指定字段,且字段相同的行连接起来。在这里,它能够将两个文件中指定字段的相同字段连接起来,并成一行。
join [-参数] 文件1 文件2
-t:两个文件的字段分隔符
-1:第一个文件的字段
-2:第二个文件的字段
-i:忽略选取字段的大小写
该命令能将一个大文件切分成若干个小文件。
split [-参数] 大文件 小文件名字前缀
-b:指定小文件的大小,需要加上单位:b、k、m
-l:指定每个小文件中的行数。
大文件会被切分成若干个小文件,且小文件的名字为:小文件名字前缀+aa、小文件名字前缀+ab、小文件名字前缀+ac