文本编辑器grep、sed 正则练习题

作业一:grep作业(正则表达式及字符处理)

目标文件/etc/passwd,使用grep命令或egrep

1.显示出所有含有root的行:

	grep  'root' passwd

2.输出任何包含bash的所有行,还要输出紧接着这行的上下各两行的内容:

	grep -C 2 'bash passwd

3.显示出有多少行含有nologin。

    grep -c 'nologin' passwd

4.显示出那些行含有root,并将行号一块输出。

	grep -n 'root' passwd

5.显示出文件

egrep -l 'root' passwd

6.新建用户

abominable

abominate

anomie

atomize

编写正则表达式,将他们匹配出来

egrep '^a[a-Z]*e' passwd

7.建四个用户

Alex213sb

Wpq2222b

yH438PIG

egon666

egon

过滤出用户名组成是字母+数字+字母的行

egrep "^([a-Z]+)([0-9]+)([a-Z]+)" passwd

8.显示出/etc目录下所有包含root的文件名

新建一个文件:zhengze
将/etc下的文件名全保存进去:

a=$(ls /etc)

echo $a > zhengze

cat zhengze

显示出包含root的名字:

egrep -o ' [a-Z0-9.]*root[a-Z0-9.]* ' zhengze


    没有输出  所以没有包含root名字的文件

9.过滤掉/etc/ssh/sshd_config内所有注释和所有空行

egrep '^[^#]' sshd_config

作业二:Sed作业:以/etc/passwd文件为模板

1,删除文件每行的第一个字符。

sed  's/^.//' passwd

2,删除文件每行的第二个字符。

sed -r 's/^(.)(.)(.*)/13/' passwd

3,删除文件每行的最后一个字符。

sed  's/.$//' passwd

4,删除文件每行的倒数第二个字符。

sed -r 's/(.*)(.)(.$)/13/'  passwd

5,删除文件每行的第二个单词。

sed -r 's/([^a-Z0-9])([a-Z0-9]*)([^a-Z0-9])(.+)/134/' passwd

6,删除文件每行的倒数第二个单词。

sed -r 's/(.+)([^a-Z0-9])([a-Z0-9]+)([^a-Z0-9])([a-Z0-9]+)/1245/' passwd

7,删除文件每行的最后一个单词。

sed -r 's/(.+)([^a-Z0-9])([a-Z0-9]+)/12/' passwd

8,交换每行的第一个字符和第二个字符。

sed -r 's/(.)(.)(.+)/213/' passwd

9,交换每行的第一个字符和第二个单词。

sed -r 's/(.)([a-Z0-9]+)([^a-Z0-9]+)([a-Z0-9]+)([^a-Z0-9]+)(.*)/423156/' passwd

10,交换每行的第一个单词和最后一个单词。

sed -r 's/^([a-Z]+)([^a-Z]+)(.*)([^a-Z]+)([a-Z]+)$/52341/' passwd

11,删除一个文件中所有的数字。

sed -r 's/[0-9]//g' passwd

12,删除每行开头的所有空格。

 sed -r 's/^ *//g' passwd	

13,用制表符替换文件中出现的所有空格。

sed -r 's/ /	/g' passwd

14,把所有大写字母用括号()括起来。

sed -r 's/[A-Z]/(&)/g' passwd

15,打印每行3次。

sed -r 'p;p' passwd

16,只显示每行的第一个单词。

sed -r 's/^([a-Z]+)([^a-Z]+)(.*)/1/' passwd

17,打印每行的第一个单词和第三个单词。

sed -r 's/(^[a-Z]+)([^a-Z]+)([a-Z]+)([^a-Z]+)([a-Z]+)(.*)/1 5/' passwd

18,用命令获取格式为 mm/yy/dd 的日期格式,结合管道,将其换成 mm;yy;dd格式

原文地址:https://www.cnblogs.com/G-YUE/p/6601359.html