Shell编程基础 Part02_文本处理与test命令
1.grep与egerp命令
用法如下:
grep
-i ##忽略字母大小写
-v ##条件取反
-c ##统计匹配行数
-q ##静默,无任何输出
-n ##显示匹配结果所在的行号
注意:ergep(extend grep)用法与grep命令相同
首先我们可以看到 /etc /hosts文件内容如下:
过滤含有172.25.254.254的行:
统计匹配行数:
显示匹配结果所在的行号:
条件取反,过滤所有不含172.25.254.254的行:
我们可以看到file文件源文件内容如下:
过滤file中前10行中含有a的行:
2.基本元字符
1.基本元字符:^ $
过滤/etc/passwd文件中以root开头的行,在过滤/etc/passwd文件中以bash结尾的行:
过滤/etc/passwd文件中以root开头的行或者以bash结尾的行:
2.基本元字符:. ##过滤非空行
3.基本元字符: + ? *
首先,源文件file1的内容如下:
过滤含有1个f及以上的行,和含有4个f及以上的行:
过滤color或者colorful?:
过滤全部含有co或者col的行:
4.元字符:{}
file1文件内容如下:
过滤含有3个we的行,再过滤含有2个及以上we的行,再过滤含有1或者2个we的行:
过滤we后面跟a或者b的行,在过滤含有大写字母A-Z的行(大写字母在实验前添加到file1文件中):
2.cut命令
cut -d ##指定分隔符
cut -d : -f 1-3 /etc/passwd ##指定分隔符为:,显示第1到3列
cut -c 1,4 /etc/passwd ##显示第一和第四个字符
结果如下:
练习:获取主机IP
3.sort命令
sort
-n ##纯数字排序
-r ##倒序
-u ##去掉重复数字
-o ##输出到指定文件中
-t ##指定分隔符
-k ##指定要排序的列
首先源文件fiel内容如下:
file2内容如下:
排序如下:
当不指定排序方式时,默认按照第一列的数字由小到大排序:
倒序排序:
去掉重复数字:
输出到指定文件file1中:
指定分隔符为:,并以2列有小到大排序:
4.uniq命令
uniq
-u ##显示唯一的行
-d ##显示重复的行
-c ##每行显示一次并统计重复次数
如下:
练习:将/etc/目录中的文件取出最大的
5.test命令
[ "$a" = "$b" ] ##等于
[ "$a" != "$b" ] ##不等于
[ "$a" -eq "$b" ] ##等于
[ "$a" -ne "$b" ] ##不等于
[ "$a" -le "$b" ] ##小于等于
[ "$a" -ge "$b" ] ##大于等于
[ "$a" -gt "$b" ] ##大于
[ "$a" -lt "$b" ] ##小于
[ "$a" -ne "$b" -a "$a" -gt "$b" ] ##-a必须条件都满足
[ "$a" -ne "$b" -o"$a" -gt "$b" ] ##-a条件至少满足一个
[ -z "$a" ] ##是否为空
[ -e "file" ] ##是否存在
[ -f "file" ] ##普通文件
[ -b "file" ] ##块设备
[ -S "file" ] ##套接字
[ -c "file" ] ##字符设备
[ -L "file" ] ##软链接
1.判断10以内的正整数:
执行结果如下: