1、标准输入、标准输出、错误输出概述
数据库
1.标准输入(stdin)是指令数据的输入,代码为0,使用<或者<<,默认是键盘。bash
2.标准输出(stdout)是指令执行成功返回的结果,代码为1,使用>或者>>,默认在屏幕显示。ide
3.标准错误输出(stderr)是指令执行失败返回的错误信息,代码为2,使用2>或者2>>,默认是屏幕。spa
2、数据流重定向的使用
1."<":指定输入的数据媒介来源(tr 'a-z' 'A-Z' < 文件名:将指定文件中的小写字母变为大写字母输出到屏幕)code
2.">"、"1>":将正确的内容覆盖输出到指定的媒介排序
3.">>"、"1>>":将正确的内容追加到指定的媒介ci
4."2>":将错误覆盖输出到指定的媒介it
5."2>>":将错误信息追加输出到指定的媒介class
6."&>":将正确内容和错误信息覆盖输出到指定媒介搜索
7."&>>":将正确内容和错误信息追加到指定的媒介
8.多个指令执行
bash1&&bash2(前者执行成功才会执行后者)
bash1||bash2(前者执行完毕且失败才执行后者)
3、管道命令概述
1.管道命令可以将一个命令的执行结果通过筛选,只保留咱们须要的信息。 如,/etc目录下会有大量的文件,若是使用ls很难找到须要的文件,所以可使用管道命令将ls的结果进行一次筛选,只保留须要的信息。
2.管道和数据流重定向的区别:
管道一词很是生动形象,原始数据通过管道后,管道会将一部分不须要的信息过滤掉,只保留用户所关注的信息。
数据流重定向是指定数据在哪里显示,默认状况下会在屏幕显示,咱们能够指定它输出到文件。
3.管道命令经过管道符"|"链接
4.可以接收标准输入(stdin),如tail/more/grep等
5.可以接收来自前一个指令的数据成功stdin进行处理
4、管道命令的使用
1.cut:为剪切的意思,它能将一行行的数据按照指定的分隔符切成一列列,而后只显示特定列的数据.
cut -d '分隔符' -f n 按照特定的分隔符将数据切分,并只显示第n列的数据。
cut -c 起始字符的下标-结束字符的下标 选择特定范围内的数据(cut中涉及的下标均从1开始)
2.grep:关键字查找
grep [-cinv] [--color=auto] '关键词' 待查找的文件名
-c:统计关键词出现的次数
-i:关键词忽略大小写
-n:输出行号
-v:反向选择,即查找不包含该关键字的行
--color=auto:关键词高亮
命令 | grep [-参数] ‘关键词’ 采用管道,将前一个命令的执行结果输出给grep,并经过grep的关键词搜索将符合条件的行搜索出来。
3.sort:排序
sort [-参数] 文件
-t:指定分隔符
-k:选取分隔符后的第几个字段进行排序
-f:排序时忽略选取字段的大小写
-b:取出选取字段前的空格
-M:将选取的字段按照月份来排序(前提是选取字段就是月份)
-n:将选取字段按照数据来排序(前提是选取字段就是数字)
-r:反向排序
-u:去重,若选取字段有重复,则去掉重复
命令 | sort [-参数] 使用管道,将前一个命令执行的结果按照指定字段进行排序。
4.uniq:只能用于管道,它可以去除前一个命令执行的结果中彻底同样的行。
uniq [-参数] -i:忽略大小写 -c:进行重复行的统计
5.wc:统计字数、行数、字符数
wc [-参数] 文件名
-l 列出行数
-w 列出字数
-c 列出字符数
6.tee:可以同时将命令执行的结果输出到指定的文件和屏幕。只能结合管道使用
tee [-a] 文件 -a:以追加的形式写入文件。
7.join:链接两个文件
这个命令与管道无关。 它至关于数据库中的join链接,将两张表中指定字段,且字段相同的行链接起来。在这里,它可以将两个文件中指定字段的相同字段链接起来,并成一行。
join [-参数] 文件1 文件2
-t:两个文件的字段分隔符
-1:第一个文件的字段
-2:第二个文件的字段
-i:忽略所选字段的大小写
8.split:该命令能将一个大文件切分红若干个小文件。
split [-参数] 大文件 小文件名字前缀
-b:指定小文件的大小,须要加上单位:b、k、m -l:指定每一个小文件中的行数。
大文件会被切分红若干个小文件,且小文件的名字为:小文件名字前缀+aa、小文件名字前缀+ab、小文件名字前缀+ac.