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

shell特殊符号_cut命令

概念:cut命令用来截取某一个字段
格式:cut -d '分割字符' [-cf] n,这里的n是数字,该命令选项有以下几个:
- d 后面跟分割字符,分割字符要用单引号括起来
- c 后面接的是第几个字符
- f 后面接的是第几个区块

cut命令用法以下

[root@localhost do]# cat /etc/passwd |head -2
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[root@localhost do]# cat /etc/passwd |head -2 |cut -d ':' -f 1
root
bin
[root@localhost do]# cat /etc/passwd |head -2 |cut -d ':' -f 1,2
root:x
bin:x
[root@localhost do]# cat /etc/passwd |head -2 |cut -d ':' -f 1-3
root:x:0
bin:x:1linux

cat passwd这个文件,head只查看前两行,cut -d截取分割符号为“:”, -f 1 表示截取第一段,1,2表示前两段,1-3表示头三段。

sort排序_wc统计行数_uniq删除重复行

sort命令介绍

sort命令用于排序
格式:sort [-t 分隔符] [-kn1,n2] [-nru]
这里-n1和n2指的是数字,其余选项以下:
-t 后面跟分割字符,做用跟cut -d选项同样,截取符号是什么;
-n 表示使用纯数字排序,字母及特殊符号表示为0;
-r 表示反向排序;
-u 表示除去重复;
-kn1,n2 表示由n1区间排序到n2区间,能够只写-kn1,即对n1字段排序。
  • 例:如sort不加任何选项,他是默认升序输出,咱们假设看passwd配置文件前五行有什么区别。

    [root@localhost /]# head -n5 /etc/passwd |sort 
    #查看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/bashshell

例2:把passwd配置文件前10行写到3.txt,再加几个特殊符号数字进行排序。bash

2018.4.21 五周第四次课(shell特殊符号,cut截取等命令)
如图所示,咱们用sort来进行排序,以数字排序 -n
[root@localhost do]# sort -n 3.txt #-n表示正序,特殊符号及字母表示为0
2018.4.21 五周第四次课(shell特殊符号,cut截取等命令)
如第一张图所示,咱们-r 给反向排序看看
[root@localhost do]# sort -r 3.txt #-r表示反序
2018.4.21 五周第四次课(shell特殊符号,cut截取等命令)测试

wc 命令介绍,用于来统计

概念:wc命令用于统计文档的行数,字符数或词数。
选项:
-l 统计行数
-m 统计字符数
-w 统计词数,以空格做为区分
  • 具体操做以下:

    [root@localhost do]# wc /etc/passwd #查看这个文档的行数,词数及字数
    19 27 846 /etc/passwd
    [root@localhost do]# wc -l /etc/passwd #统计行数
    19 /etc/passwd
    [root@localhost do]# wc -m /etc/passwd #统计字数
    846 /etc/passwd
    [root@localhost do]# wc -w /etc/passwd #统计行数
    27 /etc/passwdspa

命令uniq 删除重复的行

概念:uniq命令用来删除重复的行,更名了只有-c选项比较经常使用;
它表示统计重复的行数,并把行数写在前面。
  • 编写一个文件,示例以下:.net

    [root@localhost do]# touch 4.txt #建立一个文本
    [root@localhost do]# vi 4.txt #编辑内容
    111
    222
    333
    111code

  • 使用uniq前,必须献给文件排序,不然无论用,示例以下:

    [root@localhost do]# cat 4.txt #查看里面的内容
    111
    222
    333
    111
    [root@localhost do]# uniq 4.txt #测试一下看看不排序管用么,无论用的
    111
    222
    333
    111
    [root@localhost do]# sort 4.txt |uniq #sort排序4.txt文件,再输出给uniq删除重复行
    111
    222
    333
    [root@localhost do]# sort 4.txt |uniq -c #统计重复的有行,有多少
    2 111
    1 222
    1 333blog

命令tee,重定向并显示内容

tee命令后面跟文件名,起做用相似于重定向>,但它比重定向多一个功能;
把echo输出的结果,经过管道符“|” tee输出给后面的文件并在屏幕上显示。
  • 具体操做以下:

    [root@localhost do]# touch 1.txt #建立一个文本
    [root@localhost do]# echo "1321asd123" | tee 1.txt #把echo的内容经过管道符号,输出给 tee命令,到1.txt文件,而且在屏幕显示结果。
    1321asd123排序

命令tr,用于替换字符

tr命令用于替换字符,经常使用来处理文档中出现的特殊符号;
如DOS文档中出现的符号^M,该命令经常使用的选项以下:
-d 表示删除某个字符,后面跟要删除的字符;
-s 表示删除重复的字符。
  • 假设把一个文件的小l,改为大L

    [root@localhost do]# echo "linux" > 1.txt 
    [root@localhost do]# cat 1.txt 
    linux
    [root@localhost do]# echo "linux" | tr '[l]' '[L]' #把前面的小l,改为L
    Linux文档

命令split,切割文档

split命令用于切割文档,经常使用的选项为-b和-l
-b 表示依据大小来分割文档,默认单位为byte(字节)
-l 表示依据行数来分割文档
  • 先搜索出来个内容,而且全部的内容cat出来,追加剧定向到一个文件去

    [root@localhost /]# find /etc/ -type f -name "*conf" -exec cat {} >> /tmp/do/1.txt \;
    #find 搜索 /etc/ 下的文件 名字问conf结尾的文件,cat {}查看出来的内容,追加到1.txt文件中。
    [root@localhost /]# du -sh /tmp/do/1.txt #查看这个文件的大小
    212K /tmp/do/1.txt

  • 示例1:这个文件有212K,咱们给他切割指定大小为100K试试,示例以下:

    2018.4.21 五周第四次课(shell特殊符号,cut截取等命令)
    #这里,-b 指定带下100K,不加单位默认是以字节显示。

  • 示例2:指定目标文件名123开头的文件。

    2018.4.21 五周第四次课(shell特殊符号,cut截取等命令)
    #x开头的文件,是示例1的结果,不须要看他,看123开头的文件,造成一个对比。

shell特殊符号

重点章节,之后会常常用到```

#### 特殊符号 $
- 符号$能够用做变量前面的标识符,还能够和!结合起来使用,示例以下:
>[root@localhost do]# 
[root@localhost do]# ls /tmp/do/
123aa  1.txt  2.txt  3.txt  4.txt  a.txt  xaa  xab  xac
[root@localhost do]# !ls
ls /tmp/do/
123aa  1.txt  2.txt  3.txt  4.txt  a.txt  xaa  xab  xac
!$表示上条命令中的最后一个变量。

#### 特殊符号 ;
- 若是想在一行中运行两个或两个以上的命令,须要在命令之间加符号;示例以下:
>[root@localhost dior1]# mkdir 123 ; touch 1.txt ; touch 2.txt ; ls
123  1.txt  2.txt
如上含义,建立了个目录,又建立了2个文件,而且最后ls查看执行

#### 特殊符号 ~
- 符号~ 表示用户的家目录,root用户的家目录是/root,普通用户是/home/username

#### 特殊符号 &
- 若是想把一条命令放到后台执行,则须要加上符号&,它一般用于命令运行时间较长的状况,能够用在sleep(休眠),示例以下:
>[root@localhost ~]# sleep 30 & 
[1] 40966
[root@localhost ~]# jobs 
[1]+  运行中               sleep 30 &

#### 重定向符号> 、>> 、2> 、 2>>  、 &> 的用法

概念:>、>>他们分别表明取代(>)和追加(>>)的意思;
当咱们运行一个命令报错时,报错信息会输出到当前屏幕;
若是想重定向到一个文本,则须要用重定向符号2>或2>>;
他们分别表示错误重定向和错误追加剧定向。
&>表示错误和正确的重定向输入到一个文件里去

#### 中括号[] 
- 中括号内为字符组合,表明字符组合中的任意一个。(上一章节有提到)

#### 特殊符号 &&和||
- 使用||时,表示或者,意思是说 若是两条命令用||分割的话,第一条执行成功后,第二条就不会执行,假如第一条命令是错误的话,执行失败就会执行第二条。
> 示例1,假设两个命令都是正确的
> [root@localhost do]# ls 1.txt || wc -l 2.txt 
1.txt

>示例2: 假设第一条命令是错误的,而第二条命令是正确的,就会执行第二条
[root@localhost do]# ls 111111.txt || wc -l 2.txt  #在这里 根本就没有一串1的txt文件
ls: 没法访问111111.txt: 没有那个文件或目录
0 2.txt

- 使用&& 表示前面的命令执行成功之后,才会执行后面的命令,若是前面命令执行不成功,后面的命令就不会执行。用&&分割,用来判断的。
>示例1,两条命令都是正确的状况下 
>[root@localhost do]# ls 1.txt && wc -l 2.txt #ok,在这里两条命令都生效
1.txt
0 2.txt

>示例2,假如第一条命令不成功,后面的命令就不会执行。
>[root@localhost do]# ls 111.txt && wc -l 2.txt 
ls: 没法访问111.txt: 没有那个文件或目录

# 普通特殊符号介绍
  • 任意个任意字符 ? 任意一个字符 #注释字符 \ 脱义字符 | 管道符
相关文章
相关标签/搜索