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

      Awk使用案例总结(运维必会)