liunx的特殊符号
- 代表字母或者数字 多个
? 任意一个字符
"#" 注释
\ 脱义字符
| 管道符
1.* 代表任意个任意字符或者数字
[root@localhost /]# ls *.txt
1.txt
[root@localhost /]#
2.?任意一个字符
[root@localhost /]# ls ?.txt
1.txt
[root@localhost /]#
3.注释
[root@localhost /]# #11111
[root@localhost /]#
PS:意思就代表着说明
4、\脱义
[root@localhost /]# ls .txt
1.txt
[root@localhost /]# ls *.txt
ls: 无法访问.txt: 没有那个文件或目录
[root@localhost /]#
5.管道符
[root@localhost /]# cat /etc/passwd|grep root
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
[root@localhost /]#
cut命令
命令类型
文件管理
命令描述
用来截取某一个字段来显示出来
命令语法
cut 【参数】
参数
-d, --delimiter=分界符 使用指定分界符代替制表符作为区域分界
-c, --characters=列表 只选中指定的这些字符
-f :指定某一段
案例:查看/etc/passwd文件 以:为分割符 显示 第一段
[root@localhost /]# cat /etc/passwd|head |cut -d ":" -f 1
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
[root@localhost /]#
sort命令
命令描述
此命令就是用来针对文档进行排序的
命令语法
sort [参数] [文件]
参数
-t 分割符:和cut -d 一样
-n :使用纯数字排序
-r :方向排序
-u :去重复
-k :-kn1,n2 :由n1区间排序到n2区间,可以只写-kn1,即对n1字段排序
案例一:不加任何参数,会用ASCII码值进行比较,最后将他们按升序输出。
[root@localhost /]#
[root@localhost /]# head /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
halt:x:7:0:halt:/sbin:/sbin/halt
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
root:x:0:0:root:/root:/bin/bash
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
sync:x:5:0:sync:/sbin:/bin/sync
[root@localhost /]#
WC命令
命令描述
用于统计
命令语法
wc [参数]
参数
-l:统计行数
-m:统计字符数
-w:统计词数
案例
[root@localhost /]# cat /etc/passwd |wc -l -m -w
19 29 883
[root@localhost /]# cat /etc/passwd |wc
19 29 883
[root@localhost /]#
PS:其实不需要加参数的
unip命令
命令描述
用来删除重复的行
命令语法
xxxxx|unip
参数
-c 统计重复的行数
案例
[root@localhost ~]# uniq testb.txt
111
222
111
333
[root@localhost ~]# sort testb.txt |uniq
111
222
333
[root@localhost ~]# sort testb.txt |uniq -c
2 111
1 222
1 333
tee命令
tee后面跟文件名,其作用类似于重定向>,比重定向多一个功能,把文件写入后面所跟的文件时并显示在屏幕上,通常用于管道符 |后。
案例
#echo “aaaaaaaaaaaaaaa” |tee testb.txt
aaaaaaaaaaaaaaa
#cat testb.txt
aaaaaaaaaaaaaaa
命令tr
tr用于替换字符,常用来处理文档中出现的特殊符号,如DOS文档中出现的符号 ^M 。
选项:
参数
-d 表示删除某个字符,后面跟要删除的字符。
-s 表示删除重复的字符。
把小写字母变成大写字母,如tr’[a-z]’’[A-Z]’:
案例
#head –n2 /etc/passwd |tr’[a-z]’’[A-Z]’
ROOT:X:O:O:ROOT:/ROOT:/BIN/BASH
BIN:X:11:BIN:/BIN:/SBIN/NOLOGIN
还可以替换一个字符:
#grep ‘root’ /etc/passwd |tr ‘r’ ‘R’
Root:x:o:o:Root:/Root:/bin/bash
opeRatoR:x:11:0:opeRatoR:/Root:/sbin/nologin
命令split
命令描述
split用于切割文档,常用的选项为-b和-l。
参数
-b 表示依据大小来分割文档,单位为byte
-l 表示依据行数来分割文档
案例
#split –b 500 passwd
#ls
passwd xaa xab xac xad xae
shell一些其他特殊符号
1、特殊符号$
$可以用作变量前面的标识符,还可以和!结合使用。
#cd ..
#ls testb.txt
testb.txt
#ls !$
ls testb.txt
testb.txt
!$表示上条命令的最后一个变量,本例中上条命令最后是testb.txt,那么在当前命令下输入!$则表示testb.txt。
2、特殊符号;
在一行命令中运行两个或两个以上的命令,需要在命令之间加符号;。
#mkdir testb.txt ; touch test1.txt ; touch test2.txt ; ls –d test* 创建目录、创建文件、列出目录
3、特殊符号~
符号~代表用户的家目录,root用户的家目录是/root,普通用户的家目录是/home/username。
4、特殊符号&
把一条命令放到后台执行,则需要加上符号&,它通常用于命令运行时间较长的情况。比如,可以用在sleep后,如下所示:
#sleep 30 &
[1]3008
#jobs
[1]+ 运行中 sleep 30 &
5、重定向符号>、>>、2>和2>>
和>>分别表示取代和追加的意思。当我们运行一个命令报错时,报错信息会输出到当前屏幕。如果想重定向到一个文本,则要用重定向符号2>或者2>>,它们分别表示错误重定向和错误追加重定向。
#ls aaaa
ls:无法访问aaaa:没有那个文件或目录
#ls aaaa 2> /tmp/error
#cat /tmp/error
ls:无法访问aaaa:没有那个文件或目录
#ls aaaa 2>> /tmp/error
#cat /tmp/error
ls:无法访问aaaa:没有那个文件或目录
ls:无法访问aaaa:没有那个文件或目录
6、中括号[ ]
中括号内为字符组合,代表字符组合中的任意一个,还可以表示一个范围(1-3,a-z)。
#cd /tmp/10
#ls –d test*
test1.txt test2.txt testb.txt testdir
#ls –d test[1-3].txt
test1.txt test2.txt
#ls –d test[12b].txt
test1.txt test2.txt testb.txt
#ls –d test[1-9].txt
test1.txt test2.txt
#ls –d test[1-9a-z].txt
test1.txt test2.txt testb.txt
7、特殊符号&& ||
在上面刚刚提到了分号,用于多条命令间的分隔符。另外还有两个可以用于多条命令中间的特殊符号,那就是 “&&” 和 “||” 下面把这几种情况全列出:
command1 ; command2
command1 && command2
command1 || command2
使用 ”;” 时,不管command1是否执行成功都会执行command2;
使用 “&&” 时,只有command1执行成功后,command2才会执行,否则command2不执行;
使用 “||” 时,command1执行成功后command2 不执行,否则去执行command2,总之command1和command2总有一条命令会执行。
本文转自 闪电王 51CTO博客,原文链接:http://blog.51cto.com/sdwaqw/2060908