我爱小虾 发表于 2018-8-24 08:49:19

shell特殊符号,cut、sort、wc、uniq、tee、tr、split命令

  *代表0个或多个任意字符
  # ls *txt
  11.txt1.txt22.txt2.txtaa.txta.txt
  ?只代表一个任意字符
  不管是数字还是字母,只要是一个字符的都能匹配出来
  # ls ?.txt
  1.txt2.txta.txtb.txt
  # ls ?txt
  ls: 无法访问?txt: 没有那个文件或目录
  注释符号#,这个符号后面的内容都会被忽略
  # a=123 #456
  # echo $a
  123
  脱义字符 \,这个字符会将后面的特殊符号(如*)还原为普通字符。
  # ls -ld test*
  drwxr-xr-x. 2 root root 6 11月 17 14:06 test
  # ls -ld test\*
  ls: 无法访问test*: 没有那个文件或目录
  管道符 | ,它的作用是将前面命令的输出作为后面命令的输入。并不是所有命令都可以用在管道符中,常用命令:cat、less、head、tail、grep、cut、sort、wc、uniq、tr、split、sed、awk等。
  # cat 1.txt | wc -l
  1
  cut命令
  cut命令用来截取某一个字段。
  格式为:cut -d‘分隔符 ’-n,n为数字。
  -d:后面跟分隔符,分隔符要用单引号引起来。
  -f:后面接的是第几个区块
  -c:后面接的是第几个字符
  (-c不需要和-f,-d需要-f)
  # head -5 /etc/passwd | cut -d ':' -f 1-4
  root:x:0:0
  bin:x:1:1
  daemon:x:2:2
  adm:x:3:4
  lp:x:4:7
  -d后的冒号为分隔符,-f 1-4表示截取1-4段
  # head -5 /etc/passwd | cut -c 1-4
  root
  bin:
  daem
  adm:
  lp:x
  -c后可以是1个数字,也可以是区间1-4,还可以是多个数字n1,n2,n3(用逗号隔开)。
  # head -5 /etc/passwd | cut -c 1,6,8
  rx0
  b::
  dnx
  a::
  l47
  sort命令
  sort命令用作排序。
  格式为:sort -[-t 分隔符] [-kn1,n2] [-nru] n1,n2为数字。
  -t:后面跟分割字符,作用和cut -d一样。
  -n:表示使用纯数字排序。
  -r:表示反向排序。
  -u:表示去除重复。
  -kn1,n2:表示n1-n2区间排序,也可以只写-kn1。
  如果sort不加任何选项,则凶首字符向后一次按ASCII码值进行比较,最后将它们按升序输出。
  # head -n 5 /etc/passwd | sort
  adm:x:3:4:adm:/var/adm:/sbin/nologin
  bin:x:1:1:bin:/bin:/sbin/nologin
  daemon:x:2:2:daemon:/sbin:/sbin/nologin
  lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  root:x:0:0:root:/root:/bin/bash
  -t选项后跟分隔符,-k选项后跟一个数字表示对第几个区域的字符串排序,-n选项则表示使用纯数字排序。
  # head -n 5 /etc/passwd | sort -t ':' -k 3 -n #将第三段的字符用纯数字排序。
  root:x:0:0:root:/root:/bin/bash
  bin:x:1:1:bin:/bin:/sbin/nologin
  daemon:x:2:2:daemon:/sbin:/sbin/nologin
  adm:x:3:4:adm:/var/adm:/sbin/nologin
  lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  -k选项后面跟数字n1,n2表示对n1和n2这个区域内的字符串排序,-r反向排序。
  # head -n 5 /etc/passwd | sort -t ':' -k 3,5 -r #将第三至五段区间内的字符串进行反向排序。
  lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  adm:x:3:4:adm:/var/adm:/sbin/nologin
  daemon:x:2:2:daemon:/sbin:/sbin/nologin
  bin:x:1:1:bin:/bin:/sbin/nologin
  root:x:0:0:root:/root:/bin/bash
  wc命令
  wc命令用于统计文档的行数、字符数、或词数。
  -l 统计行数
  -w 统计词数
  -m 统计字符数
  wc后不跟任何参数直接跟文档则会把行数、词数、字符数依次输出。
  # wc /etc/passwd
  24   44 1128 /etc/passwd
  # wc -l /etc/passwd
  24 /etc/passwd
  # wc -w /etc/passwd
  44 /etc/passwd
  # wc -m /etc/passwd
  1128 /etc/passwd
  uniq命令
  uniq命令用来删除重复行,常用选项-c,表示统计重复的行数,并把行数写在前面。
  使用uniq前,必须要先给文件排序(sort),否则不管用。

  tee命令
  tee命令后根文件名,起作用类似于输出重定向(>),它还能把写入后面所跟文件时,还显示在屏幕上。常用于管道符 | 后。
  -a:向文件中重定向时使用追加模式

  使用-a参数。追加。

  tr命令
  tr命令用于替换字符,常用来处理文档中出现的特殊符号。
  -d 表示删除某个字符。
  # echo "huangdalinux" | tr 'a' 'A'
  huAngdAlinux#将字符串中的a替换成A
  # echo "huangdalinux" | tr 'an' 'AN'
  huANgdAliNux#将字符串中的a和n替换成A和N
  # echo "huangdalinux" | tr 'a-z' 'A-Z'
  HUANGDALINUX#将字符串中的小写字母替换成大写字母
  使用-d参数,删除字符串中的某个字符
  # echo "huangdalinux" | tr -d 'a'
  hungdlinux
  # echo "huangdalinux" | tr -d 'a,u'
  hngdlinx
  s
  plit命令
  split命令用于切割文档,常用选项为-b和-l
  -b:表示依据大小来分割文档,默认单位为byte。



  -l:表示依据行数来分割文档。

  指定目标文件名。

  特殊符号$,用作变量前面的标识符。
  特殊符号;。如果想在一行中运行两个或两个以上的命令,需要再命令之间加符号;。
  特殊符号~。表示用户的家目录,root用户为/root,普通用户为/home/用户名/
  特殊符号&。可以把一条命令放在后台执行。接在命令后。
  输出重定向>,输出重定向追加>>,错误重定向2>,错误重定向追加2>>, 正确和错误输出都重定向&>.正确和错误输出都重定向追加&>>
  中括号[],中括号内为字符组合,代表字符组合中的任意一个,可以是一个范围。
  特殊符号&&和||
  command1;command2
  使用;时,不管command1是否执行成功,都会执行command2。
  command1&&command2
  使用&&时,只有command1执行成功,才会执行command2。
  command1||command2
  使用||时,command1执行成功后则command2不执行,否则执行command2,即command1和command2中总有一条命令会执行。

页: [1]
查看完整版本: shell特殊符号,cut、sort、wc、uniq、tee、tr、split命令