把/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.txt2. ?sed -n '3,10'p test.txt3. ?sed -n '/root/'p test.txt4. ?sed '15,$'d ?test.txt5. ?sed '/bash/'d test.txt6. ?sed 's/root/toor/g' test.txt7. ?sed 's#sbin/nologin#bin/login#g' test.txt8. ?sed '5,10s/[0-9]//g' test.txt9. ?sed 's/[^0-9a-zA-Z]//g' test.txt10. ?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.txt11. ?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.txt12. ?sed 's#\([^0-9][^0-9]*\)\([0-9][0-9]*\)\([^0-9].*$\)#\1\3\2#' test.txt13. ?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.txt2. awk '/bash/' test.txt3. awk -F':' '$3=="0"' test.txt4. awk -F':' '$1=="root"' test.txt |sed 's/root/toor/'5. awk -F':' '{print $NF}' test.txt6. awk -F':' 'NR>20' test.txt7. awk -F':' '$3<$4' test.txt8. awk -F':' '{print $1"@"$NF}' test.txt9. awk -F':' '{(sum+=$4)}; END {print sum}' test.txtAwk使用案例总结(运维必会)