管线符号 | 仅能处理经由前面一个指令传来的正确信息,也就是 standard output ( STDOUT ) 的信息.

1,cut

取出一段文本,以行为单位

1
2
3
4
5
6
$ cut -d `分隔字符` -f 第几个字段
$ cut -c 字符区间
参数:
-d :后面接分隔字符。与 -f 一起使用;
-f :依据 -d 的分隔字符将一段讯息分割成为数段,用 -f 取出第几段的意思;
-c :以字符 (characters) 的单位取出固定字符区间;

2,wc

统计字符,行数等

1
2
3
4
5
$ wc [-lwm]
参数:
-l :仅列出行;
-w :仅列出多少字(英文单字);
-m :多少字符;

3,grep

1
2
3
4
5
6
7
8
$ grep [-acinv] [--color=auto] '搜寻字符串' filename
选项与参数:
-a :将 binary 文件以 text 文件的方式搜寻数据
-c :计算找到 '搜寻字符串' 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
--color=auto :可以将找到的关键词部分加上颜色的显示!

4,正则表达式

1
2
3
4
5
6
7
8
9
10
11
12
特殊字符 表示意义
^word 待搜寻的字符在行首
word$ 待搜寻的字符在行尾
. 匹配任何一个可能的字符
\ 跳脱符号将特殊字符变成普通字符
? 任何一个单一字符
* 匹配模式中重复的字符
[list] 列表中的字符
[range] 列表中范围内的字符
[^range] 反向选择,与 [list] 相反
{n} 与前一个相同字符连续 n 个
{n,m} 与前一个相同字浮连续 n-m 个

5,sed

把之前的结果按照一行一行放到缓冲区,然后按照【动作】进行处理,之后返回处理后的结果注意,操作的是前边的结果,不会对源文件尽心

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
sed [-nefr] [动作]
选项与参数:
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。
动作说明: [n1[,n2]]function
n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』
function
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行
s :取代,可以直接进行取代的工作,通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g

6, awk

awk是一个文本分析工具,把文件逐行读入,用空格分割切片处理

1
awk '{文件中的查找内容 + 操作}' {文件名}