作业一: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格式