十二12 发表于 2018-8-27 10:42:09

shell grep sed awk 练习

  把/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///g' test.txt
  9. ?sed 's/[^0-9a-zA-Z]//g' test.txt
  10. ?sed 's/\(^*\)\([^a-zA-Z].*\)\([^a-zA-Z]\)\(*$\)/\4\2\3\1/' test.txt
  11. ?sed 's#\([^0-9][^0-9]*\)\(*\)\([^0-9].*\)\([^a-zA-Z]\)\(*$\)#\1\5\3\4\2#' test.txt
  12. ?sed 's#\([^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
页: [1]
查看完整版本: shell grep sed awk 练习