博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
shell特殊符号cut命令,sort、wc、uniq命令,tee、tr、split命令
阅读量:6272 次
发布时间:2019-06-22

本文共 4496 字,大约阅读时间需要 14 分钟。

hot3.png

shell特殊符号_cut命令

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

cut命令用法如下

[root do]# cat /etc/passwd |head -2

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

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 /]# 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/bash

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

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/passwd

命令uniq 删除重复的行

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

    [root@localhost do]# touch 4.txt #创建一个文本

    [root@localhost do]# vi 4.txt #编辑内容
    111
    222
    333
    111

  • 使用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 333

命令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: 没有那个文件或目录

普通特殊符号介绍

* 任意个任意字符 ? 任意一个字符 #注释字符 \ 脱义字符 | 管道符

转载于:https://my.oschina.net/u/3830571/blog/1800648

你可能感兴趣的文章
融了1000万,只为让它们好好吃饭!
查看>>
Debian 项目领导人职位已有三位侯选者
查看>>
阿里巴巴与三个知名车企达成合作,将为其“AI+车”解决方案
查看>>
django小项目:搭建简易火车车票预订系统
查看>>
仅研发就投入3300人 华为如何掘金物联网?
查看>>
表单调试工具推荐
查看>>
Kubernetes node的防火墙问题导致pod ip无法访问
查看>>
hdfs-site.xml配置
查看>>
为什么多线程读写 shared_ptr 要加锁?
查看>>
netware 6.5的故障解决
查看>>
linux 同步IO: sync、fsync与fdatasync
查看>>
笼络人才,再三“表白”,库克表示苹果更看重AR
查看>>
[原创]对于运行ASP.NET程序时,提示:无法启动程序“http://localhost:3532/Default.aspx”。的疑问...
查看>>
潮鞋的AR初体验,鬼冢虎和Anrealage合作新鞋
查看>>
4星|《错误的行为》:经济行为中大部分时候人们是不理性的
查看>>
java中包容易出现的错误及权限问题
查看>>
Hibernate5-查询与排序
查看>>
硬盘速度测试
查看>>
mouseout、mouseover和mouseleave、mouseenter区别
查看>>
一句话命令
查看>>