命令 : cut 用来截取某一个字段 语法: cut -d ‘分隔字符’ [-cf] n 这里的n是数字 -d :后面跟分隔字符,分隔字符要用单引号括起来 -c :后面接的是第几个字符 -f :后面接的是第几个区块
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -d ':' -f 1
root
bin
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -d ':' -f 1,2
root:x
bin:x
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -d ':' -f 1-3
root:x:0
bin:x:1
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -d ':' -f 1-4
root:x:0:0
bin:x:1:1
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -c1-4
root
bin:
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -c1
r
b
[root@xie-02 ~]# cat /etc/passwd | head -2 | cut -c2
o
i
命令 : sort sort 用做排序 语法: sort [-t 分隔符] [-kn1,n2] [-nru] 这里的n1 < n2 -t 分隔符 :作用跟cut的-d一个意思 -n :使用纯数字排序 -r :反向排序 -u :去重复 -kn1,n2 :由n1区间排序到n2区间,可以只写-kn1,即对n1字段排序 PS:如果sort不加任何选项,则从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。不会更改文件内容
命令 : wc 用于统计文档的行数、字符数、词数,常用的选项为: -l :统计行数 -w :统计词数 -m :统计字符数 PS:wc 不跟任何选项,直接跟文档,则会把行数、词数、字符数依次输出
[root@xie-02 ~]# cat -A 1.txt //-A包括隐藏的都会显示
123$
asd$
zxc$
345$
[root@xie-02 ~]# wc -l 1.txt //统计行数
4 1.txt
[root@xie-02 ~]# wc -w 1.txt //统计词数
4 1.txt
[root@xie-02 ~]# wc -m 1.txt //统计字符数
16 1.txt
[root@xie-02 ~]# wc 1.txt //把行数、词数、字符数依次输出
4 4 16 1.txt
命令 : uniq 去重复的行(去掉的是相邻的重复的行,如果不是相邻的即使重复也不会去重,所以需要先排序再去重) -c :统计重复的行数,并把行数写在前面 PS:不会更改文件内容
[root@xie-02 ~]# cat 1.txt
123
asd
123
zxc
345
1
222
1
2
2
[root@xie-02 ~]# uniq 1.txt //去掉的是相邻的重复的行
123
asd
123
zxc
345
1
222
1
2
[root@xie-02 ~]# sort 1.txt | uniq -c //先排序再去重
2 1
2 123
2 2
1 222
1 345
1 asd
1 zxc
命令 : tee 后跟文件名,类似与重定向 “>”, 但是比重定向多了一个功能,在把文件写入后面所跟的文件中的同时,还显示在屏幕上。 -a:加上参数a之后就相当于重定向的追加>>
[root@xie-02 ~]# echo "213asdf" | tee 1.txt
213asdf
[root@xie-02 ~]# cat 1.txt
213asdf
命令 : tr 替换字符,常用来处理文档中出现的特殊符号,如DOS文档中出现的^M符号。常用的选项有两个: -d :删除某个字符,-d 后面跟要删除的字符 -s :把重复的字符去掉 最常用的就是把小写变大写: tr ‘[a-z]’ ‘[A-Z]’
[root@xie-02 ~]# echo "linux" |tee 1.txt
linux
[root@xie-02 ~]# cat 1.txt
linux
[root@xie-02 ~]# echo "linux" |tr '[li]' '[LI]'
LInux
[root@xie-02 ~]# echo "linux" |tr '[a-z]' '[A-Z]'
LINUX
命令 : split 切割文档,常用选项: -b :依据大小来分割文档,直接写数字,如100则默认是字节 -l :依据行数来分割文档 PS:如果split不指定目标文件名,则会以xaa xab… 这样的文件名来存取切割后的文件。当然我们也可以指定目标文件名
[root@xie-02 ~]# du -sh 1.txt
252K 1.txt
[root@xie-02 ~]# split -b 100k 1.txt //以100K大小切割
[root@xie-02 ~]# ls
1.txt anaconda-ks.cfg xaa xab xac
[root@xie-02 ~]# du -sh *
252K 1.txt
4.0K anaconda-ks.cfg
100K xaa
100K xab
52K xac
[root@xie-02 ~]# split -b 100k 1.txt 123 //以100K大小切割并指定目标文件名
[root@xie-02 ~]# du -sh *
100K 123aa
100K 123ab
52K 123ac
252K 1.txt
4.0K anaconda-ks.cfg
[root@xie-02 ~]# split -l 1000 1.txt //依据行数切割
[root@xie-02 ~]# wc -l *
6481 1.txt
51 anaconda-ks.cfg
1000 xaa
1000 xab
1000 xac
1000 xad
1000 xae
1000 xaf
481 xag
13013 总用量
相关测验题目:http://ask.apelearn.com/question/5437 扩展 1. source exec 区别 http://alsww.blog.51cto.com/2001924/1113112 2. Linux特殊符号大全http://ask.apelearn.com/question/7720 3. sort并未按ASCII排序 http://blog.csdn.net/zenghui08/article/details/7938975