正则表达式扩展知识练习
做业题:正则表达式
1. 如何把 /etc/passwd 中用户uid 大于500 的行给打印出来?
uid是文件passwd的第三段,因此:
awk -F ':' '$3>500 {print $0}' passwd
2. awk中 NR,NF两个变量表示什么含义?awk -F ':' '{print $NR}' /etc/passwd 会打印出什么结果出来?
NR表示行号、NF表示行的段数。 打印结果:依次打印passwd的第n行的第n段。
3. 用grep把1.txt文档中包含'abc'或者‘123’的行过滤出来,并在过滤出来的行前面加上行号.
grep -n 'abc\|123' 1.txt
4. grep -v '^$' 1.txt 这样会过滤出哪些行?
^$表明空行,因此-v取反,过滤出全部非空行。
5. '.' '' 和 '.' 分别表示什么含义? '+'和'?'表示什么含义,这五个符号是否能够在grep中使用,是否能够在egrep、sed以及awk中使用?
.表明匹配单个任意字符 *表明匹配0个或多个任意字符 .*表明匹配空字符或者任意字符串
+表明匹配1个或多个任意字符 ?表明匹配0个或者1个任意字符 。
能够在grep、egrep、sed、awk中使用
6. grep 里面用到一个 {} ,它用在什么状况下?
表示其前面字符连续出现的次数,花括号里数字,表明出现的次数。如r{3},表示r连续出现3次。
7. sed有一个选项,能够直接更改文本文件,是哪一个选项?
-i选择直接修改原文件。
8. sed -i 's/.ie//;s/["|&].//' file 这条命令表示什么操做呢?
把file文件中ie字符串及他前面的字符串都删除,"|&号及他后面的字符串都删除。并修改原文件
9. 如何删除一个文档中的全部数字或者字母?
sed 's/[0-9-a-zA-Z]//g' file ,把数字和字母替换成空字符
10. 截取日志1.log的第一段(以空格为分隔符), 按数字排序、而后去重,可是须要保留重复的数量如何作?
awk -F ' ' '{print $1}' 1.log |sort -n |uniq -c
11. 使用awk过滤出1.log中第7段(空格分隔)为'200' 而且第8段为'11897'的行。
awk -F ' ' '$7=="200" && $8=="11897" {print $0}' 1.log
12. 请比较这两个命令的异同: grep -v '^[0-9]' 1.txt 和 grep '^[^0-9]' 1.txt
第一个是:以数字开头的行匹配出来,输出打印剩余的行,包括空行。
第二个是:以非数字开头的行匹配出来并输出打印,不包括空行。
13. awk中的$0表示什么?为何如下两条命令的$0结果不一致呢? awk -F ':' '{print $0}' 1.txt 和 awk -F ':' '$7=1 {print $0}' 1.txt
$0表示文档的行以分隔符隔开后的全部段。
第一条命令:打印文件的全部行的全部段,即输出打印文件全部内容
第二条命令:匹配行的第7段为1的行,并输出打印匹配行的全部段。
14. 使用grep过滤某个关键词时,如何把包含关键词的行连同上面一行打印出来,那下面一行呢?同时上面和下面都打印出来呢?
grep -B1 'keyword' file
grep -A1 'keyword' file
grep -C1 'keyword' file