linux学习第二十五篇:cut,sort,wc,uniq,tee,tr,split命令,shell特殊符号

时间:2022-04-26
本文章向大家介绍linux学习第二十五篇:cut,sort,wc,uniq,tee,tr,split命令,shell特殊符号,主要内容包括cut命令、sort_wc_uniq命令、tee_tr_split命令、shell特殊符号、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
  • * 任意个任意字符
  • ? 任意一个字符
  • # 注释字符
  • 脱义字符
  • | 管道符
  • find /etc/ -type f -name “*conf” -exec cat {} >> 1.txt ; //在/etc下查找文件名含有conf的文件并cat查看,后追加到文件1.txt中

cut命令

命令 : 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_wc_uniq命令

命令 : 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_tr_split命令

命令 : 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 总用量

shell特殊符号

  1. $ 变量前缀,$组合,正则里面表示行尾
  2. ;多条命令写到一行,用分号分割
  3. ~ 用户家目录,后面正则表达式表示匹配符
  4. & 放到命令后面,会把命令丢到后台
  5. >:正确重定向 >>:追加正确重定向 2>:错误重定向 2>>:追加错误重定向 &>:正确错误重定向
  6. [ ] 指定字符中的一个,[0-9],[a-zA-Z],[abc]
  7. || (或者)和 &&(与) ,用于命令之间 ||:前面的命令执行成功了后面的命令就不会执行,前面的执行不成功后面命令才会执行。 &&:只有前面的命令执行成功了后面的命令才会执行。

相关测验题目: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