shell之sed awk练习

 以下练习来源:互联网

 

1. 把/etc/passwd 复制到/root/test.txt,用sed打印所有行;

2. 打印test.txt的3到10行;

3. 打印test.txt 中包含’root’的行;

4. 删除test.txt 的15行以及以后所有行;

5. 删除test.txt中包含’bash’的行;

6. 替换test.txt 中’root’为’toor’;

7. 替换test.txt中’/sbin/nologin’为’/bin/login’

8. 删除test.txt中5到10行中所有的数字;

9. 删除test.txt 中所有特殊字符(除了数字以及大小写字母);

10. 把test.txt中第一个单词和最后一个单词调换位置;

11. 把test.txt中出现的第一个数字和最后一个单词替换位置;

12. 把test.txt 中第一个数字移动到行末尾;

13. 在test.txt  20行到末行最前面加’aaa:’;

现在给出以上练习题的答案,你如果实在想不出如何操作,那你看看答案吧,请尽量多想一下。

1.  /bin/cp /etc/passwd  /root/test.txt ;  sed -n '1,$'p test.txt

2.  sed -n '3,10'p test.txt

3.  sed -n '/root/'p test.txt

4.  sed '15,$'d  test.txt

5.  sed '/bash/'d test.txt

6.  sed 's/root/toor/g' test.txt

7.  sed 's#sbin/nologin#bin/login#g' test.txt

8.  sed '5,10s/[0-9]//g' test.txt

9.  sed 's/[^0-9a-zA-Z]//g' test.txt

10.  sed 's/\(^[a-zA-Z][a-zA-Z]*\)\([^a-zA-Z].*\)\([^a-zA-Z]\)\([a-zA-Z][a-zA-Z]*$\)/\4\2\3\1/' test.txt

11.  sed 's#\([^0-9][^0-9]*\)\([0-9][0-9]*\)\([^0-9].*\)\([^a-zA-Z]\)\([a-zA-Z][a-zA-Z]*$\)#\1\5\3\4\2#' test.txt

12.  sed 's#\([^0-9][^0-9]*\)\([0-9][0-9]*\)\([^0-9].*$\)#\1\3\2#' test.txt

13.  sed 's/^.*$/&aaa/' test.txt

 
1. 用awk 打印整个test.txt (以下操作都是用awk工具实现,针对test.txt);
2. 查找所有包含’bash’的行;
3. 用’:’作为分隔符,查找第三段等于0的行;
4. 用’:’作为分隔符,查找第一段为’root’的行,并把该段的’root’换成’toor’(可以连同sed一起使用);
5. 用’:’作为分隔符,打印最后一段;
6. 打印行数大于20的所有行;
7. 用’:’作为分隔符,打印所有第三段小于第四段的行;
8. 用’:’作为分隔符,打印第一段以及最后一段,并且中间用’@’连接 (例如,第一行应该是这样的形式 “root@/bin/bash”;
9. 用’:’作为分隔符,把整个文档的第四段相加,求和;
下面给出答案:
1. awk '{print $0}' test.txt
2. awk '/bash/' test.txt
3. awk -F':' '$3=="0"' test.txt
4. awk -F':' '$1=="root"' test.txt |sed 's/root/toor/'
5. awk -F':' '{print $NF}' test.txt
6. awk -F':' 'NR>20' test.txt
7. awk -F':' '$3<$4' test.txt
8. awk -F':' '{print $1"@"$NF}' test.txt
9. awk -F':' '{(sum+=$4)}; END {print sum}' test.txt
 
 

 

你可能感兴趣的:(shell,bash,linux脚本,sed使用,awk使用)