GREP&EGREP
grep (缩写来自Globally search a Regular Expression and Print)是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行。Unix的grep家族包括grep、egrep和fgrep。Windows系统下类似命令FINDSTR。
grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。
egrep命令是一个搜索文件获得模式,使用该命令可以任意搜索文件中的字符串和符号,也可以为你搜索一个多个文件的字符串,一个提示符可以是单个字符、一个字符串、一个字、一个句子。
egrep==grep -e 支持正则表达式
1)grep,egrep
grep
-i ##忽略字母大小写
-v ##条件取反
-c ##统计匹配行数
-q ##静默,无任何输出
-n ##显示匹配结果所在的行号
统计文件/etc/passwd以/sbin/nologin结尾的行数
显示以/sbin/nologin结尾的前八行
找出文件/etc/hosts中含有172.25.4.100的一行,对比验证-q的功能
2)正则表达式
2)基本元字符:^ $
egrep -m10 ‘/sbin/nologin’ /etc/passwd
[root@server mnt]# egrep -c ‘/sbin/nologin’ /etc/passwd
35
[root@server mnt]# egrep -m10 ‘sbinKaTeX parse error: Expected 'EOF', got '#' at position 50: …oot@server mnt]#̲ cat wsp root …’ wsp ##过滤空行**
基本元字符: + ? *
[root@server ~]# egrep ‘f+’ 1.sh ##输出包括f,ff,fff…,即至少出现一次
colorful,color
colorfulful?
stuf
stuff
stufff
stuffff
stufawd
we adw dfg awda
wea web wef
[root@server ~]# egrep ‘color(ful)?’ 1.sh ##末尾的ful最多出现一次,也可以没有
color color color
colorful,color
color color.
colorfulful?
元字符:{}
[root@server ~]# egrep ‘(we){3}’ 1.sh ##含有三次we的
rere wewewe
westos wewewewe Shell
[root@server ~]#
[root@server ~]#
[root@server ~]# egrep ‘(we){2,4}’ 1.sh ##含有二到四次we的
xcvb wewe asdawd
rere wewewe
westos wewewewe Shell
[root@server ~]#
[root@server ~]# egrep ‘(we){3,}’ 1.sh ##含有三次以上we的
rere wewewe
westos wewewewe Shell
[root@server ~]# egrep ‘(we)[ab]’ 1.sh ##含有wea,web,weab的
weawe IPADDR
wea web wef
[root@server ~]# egrep ‘[A-Z]’ 1.sh ##含有大写字母A到Z的
weawe IPADDR
westos wewewewe Shell
3)cut命令
cut -d ##指定分隔符
cut -d : -f 1-3 /etc/passwd ##指定分隔符为:,显示第1到3列
cut -c 1,4 /etc/passwd ##显示第一和第四个字符
练习:获取主机ip
两种方法
4)sort命令:排序
sort
-n ##纯数字排序
-r ##倒序
-u ##去掉重复数字
-o ##输出到指定文件中
-t ##指定分隔符
-k ##指定要排序的列
[root@server ~]# sort westos
1
12
123
2
3
32
5
51
6
7
[root@server ~]# sort -n westos
1
2
3
5
6
7
12
32
51
123
[root@server ~]# sort -u westos
1
12
123
2
3
32
5
51
6
7
[root@server ~]# sort -t : -k 2 westos
2:0
12:10
2:12
3:2
51:20
5:21
123:22
32:31
5:4
6:4
1:5
51:55
123:66
7:79
[root@server ~]# sort -nt : -k 2 westos
2:0
3:2
5:4
6:4
1:5
12:10
2:12
51:20
5:21
123:22
32:31
51:55
123:66
7:79
特定排序后导入特定文件
5)uniq命令:对重复字符处理
uniq
-u ##显示唯一的行
-d ##显示重复的行
-c ##每行显示一次并统计重复次数
[root@server ~]# sort -n westos | uniq -c
1 0
1 1
2 2
1 4
1 6
1 9
2 10
1 20
1 22
2 31
1 55
[root@server ~]# sort -n westos | uniq -d
2
10
31
[root@server ~]# sort -n westos | uniq -u
0
1
4
6
9
20
22
55
练习:将/tmp目录中的文件取出最大
######test命令######
test “
a
"
=
=
"
a" == "
a"=="b” 等同于 [ “
a
"
=
=
"
a" == "
a"=="b” ]
[ “
a
"
=
"
a" = "
a"="b” ] ##等于
[ “
a
"
!
=
"
a" != "
a"!="b” ] ##不等于
[ “
a
"
−
e
q
"
a" -eq "
a"−eq"b” ] ##等于
[ “
a
"
−
n
e
"
a" -ne "
a"−ne"b” ] ##不等于
[ “
a
"
−
l
e
"
a" -le "
a"−le"b” ] ##小于等于
[ “
a
"
−
g
e
"
a" -ge "
a"−ge"b” ] ##大于等于
[ “
a
"
−
g
t
"
a" -gt "
a"−gt"b” ] ##大于
[ “
a
"
−
l
t
"
a" -lt "
a"−lt"b” ] ##小于
[ “
a
"
−
n
e
"
a" -ne "
a"−ne"b” -a “
a
"
−
g
t
"
a" -gt "
a"−gt"b” ] ##-a必须条件都满足
[ “
a
"
−
n
e
"
a" -ne "
a"−ne"b” -o"
a
"
−
g
t
"
a" -gt "
a"−gt"b" ] ##-a条件至少满足一个
[ -z “$a” ] ##是否为空
[ -e “file” ] ##是否存在
[ -f “file” ] ##普通文件
[ -b “file” ] ##块设备
[ -S “file” ] ##套接字
[ -c “file” ] ##字符设备
[ -L “file” ] ##软链接
练习
判断输入的数字是否在10以内
1.输入是否为空
2.是否在10以内
3.1<
a
<
10
−
−
>
y
e
s
4.
a<10 --> yes 4.
a<10−−>yes4.a<1 $a>10 --> no
#!/bin/bash
[ -z "$1" ] && {
echo "please input a number!"
exit 1
}
[ "$1" -gt "0" -a "$1" -lt "10" ] && {
echo "YES"
}||{
echo "NO"
}
练习
判断文件类型