shell特殊符号_cut命令
概念:cut命令用来截取某一个字段
格式:cut -d ‘分割字符‘ [-cf] n,这里的n是数字,该命令选项有如下几个:
- d 后面跟分割字符,分割字符要用单引号括起来
- c 后面接的是第几个字符
- f 后面接的是第几个区块
cut命令用法如下
[[email protected] do]# cat /etc/passwd |head -2
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[[email protected] do]# cat /etc/passwd |head -2 |cut -d ‘:‘ -f 1
root
bin
[[email protected] do]# cat /etc/passwd |head -2 |cut -d ‘:‘ -f 1,2
root:x
bin:x
[[email protected] do]# cat /etc/passwd |head -2 |cut -d ‘:‘ -f 1-3
root:x:0
bin:x:1cat 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配置文件前五行有什么区别。
[[email protected] /]# 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,再加几个特殊符号数字进行排序。
如图所示,我们用sort来进行排序,以数字排序 -n
[[email protected] do]# sort -n 3.txt #-n表示正序,特殊符号及字母表示为0
如第一张图所示,我们-r 给反向排序看看
[[email protected] do]# sort -r 3.txt #-r表示反序
wc 命令介绍,用于来统计
概念:wc命令用于统计文档的行数,字符数或词数。
选项:
-l 统计行数
-m 统计字符数
-w 统计词数,以空格作为区分
- 具体操作如下:
[[email protected] do]# wc /etc/passwd #查看这个文档的行数,词数及字数
19 27 846 /etc/passwd
[[email protected] do]# wc -l /etc/passwd #统计行数
19 /etc/passwd
[[email protected] do]# wc -m /etc/passwd #统计字数
846 /etc/passwd
[[email protected] do]# wc -w /etc/passwd #统计行数
27 /etc/passwd
命令uniq 删除重复的行
概念:uniq命令用来删除重复的行,改名了只有-c选项比较常用;
它表示统计重复的行数,并把行数写在前面。
- 编写一个文件,示例如下:
[[email protected] do]# touch 4.txt #创建一个文本
[[email protected] do]# vi 4.txt #编辑内容
111
222
333
111 - 使用uniq前,必须献给文件排序,否则不管用,示例如下:
[[email protected] do]# cat 4.txt #查看里面的内容
111
222
333
111
[[email protected] do]# uniq 4.txt #测试一下看看不排序管用么,不管用的
111
222
333
111
[[email protected] do]# sort 4.txt |uniq #sort排序4.txt文件,再输出给uniq删除重复行
111
222
333
[[email protected] do]# sort 4.txt |uniq -c #统计重复的有行,有多少
2 111
1 222
1 333
命令tee,重定向并显示内容
tee命令后面跟文件名,起作用类似于重定向>,但它比重定向多一个功能;
把echo输出的结果,通过管道符“|” tee输出给后面的文件并在屏幕上显示。
- 具体操作如下:
[[email protected] do]# touch 1.txt #创建一个文本
[[email protected] do]# echo "1321asd123" | tee 1.txt #把echo的内容通过管道符号,输出给 tee命令,到1.txt文件,并且在屏幕显示结果。
1321asd123
命令tr,用于替换字符
tr命令用于替换字符,常用来处理文档中出现的特殊符号;
如DOS文档中出现的符号^M,该命令常用的选项如下:
-d 表示删除某个字符,后面跟要删除的字符;
-s 表示删除重复的字符。
- 假设把一个文件的小l,改成大L
[[email protected] do]# echo "linux" > 1.txt
[[email protected] do]# cat 1.txt
linux
[[email protected] do]# echo "linux" | tr ‘[l]‘ ‘[L]‘ #把前面的小l,改成L
Linux
命令split,切割文档
split命令用于切割文档,常用的选项为-b和-l
-b 表示依据大小来分割文档,默认单位为byte(字节)
-l 表示依据行数来分割文档
- 先搜索出来个内容,并且所有的内容cat出来,追加重定向到一个文件去
[[email protected] /]# find /etc/ -type f -name "*conf" -exec cat {} >> /tmp/do/1.txt \;
#find 搜索 /etc/ 下的文件 名字问conf结尾的文件,cat {}查看出来的内容,追加到1.txt文件中。
[[email protected] /]# du -sh /tmp/do/1.txt #查看这个文件的大小
212K /tmp/do/1.txt - 示例1:这个文件有212K,我们给他切割指定大小为100K试试,示例如下:
#这里,-b 指定带下100K,不加单位默认是以字节显示。 - 示例2:指定目标文件名123开头的文件。
#x开头的文件,是示例1的结果,不需要看他,看123开头的文件,形成一个对比。
shell特殊符号
重点章节,以后会经常用到```
#### 特殊符号 $
- 符号$可以用作变量前面的标识符,还可以和!结合起来使用,示例如下:
>[[email protected] do]#
[[email protected] do]# ls /tmp/do/
123aa 1.txt 2.txt 3.txt 4.txt a.txt xaa xab xac
[[email protected] do]# !ls
ls /tmp/do/
123aa 1.txt 2.txt 3.txt 4.txt a.txt xaa xab xac
!$表示上条命令中的最后一个变量。
#### 特殊符号 ;
- 如果想在一行中运行两个或两个以上的命令,需要在命令之间加符号;示例如下:
>[[email protected] dior1]# mkdir 123 ; touch 1.txt ; touch 2.txt ; ls
123 1.txt 2.txt
如上含义,创建了个目录,又创建了2个文件,并且最后ls查看执行
#### 特殊符号 ~
- 符号~ 表示用户的家目录,root用户的家目录是/root,普通用户是/home/username
#### 特殊符号 &
- 如果想把一条命令放到后台执行,则需要加上符号&,它通常用于命令运行时间较长的情况,可以用在sleep(休眠),示例如下:
>[[email protected] ~]# sleep 30 &
[1] 40966
[[email protected] ~]# jobs
[1]+ 运行中 sleep 30 &
#### 重定向符号> 、>> 、2> 、 2>> 、 &> 的用法
概念:>、>>他们分别代表取代(>)和追加(>>)的意思;
当我们运行一个命令报错时,报错信息会输出到当前屏幕;
如果想重定向到一个文本,则需要用重定向符号2>或2>>;
他们分别表示错误重定向和错误追加重定向。
&>表示错误和正确的重定向输入到一个文件里去
#### 中括号[]
- 中括号内为字符组合,代表字符组合中的任意一个。(上一章节有提到)
#### 特殊符号 &&和||
- 使用||时,表示或者,意思是说 如果两条命令用||分割的话,第一条执行成功后,第二条就不会执行,假如第一条命令是错误的话,执行失败就会执行第二条。
> 示例1,假设两个命令都是正确的
> [[email protected] do]# ls 1.txt || wc -l 2.txt
1.txt
>示例2: 假设第一条命令是错误的,而第二条命令是正确的,就会执行第二条
[[email protected] do]# ls 111111.txt || wc -l 2.txt #在这里 根本就没有一串1的txt文件
ls: 无法访问111111.txt: 没有那个文件或目录
0 2.txt
- 使用&& 表示前面的命令执行成功以后,才会执行后面的命令,如果前面命令执行不成功,后面的命令就不会执行。用&&分割,用来判断的。
>示例1,两条命令都是正确的情况下
>[[email protected] do]# ls 1.txt && wc -l 2.txt #ok,在这里两条命令都生效
1.txt
0 2.txt
>示例2,假如第一条命令不成功,后面的命令就不会执行。
>[[email protected] do]# ls 111.txt && wc -l 2.txt
ls: 无法访问111.txt: 没有那个文件或目录
# 普通特殊符号介绍
- 任意个任意字符
? 任意一个字符
#注释字符
\ 脱义字符
| 管道符
原文地址:http://blog.51cto.com/13646023/2105592