linux awk sed经典题,grep sed awk 练习题

sed 练习题

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

打印test.txt的3到10行

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

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

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

替换test.txt 中 ‘root’ 为 ‘toor’

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

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

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

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

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

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

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

1:cp /etc/passwd /root/test.txt sed -n '1,$'p /root/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'

8:sed '5,10s/[0-9]//g'

9:sed 's/[^0-9a-zA-Z]//g'

10:sed -r 's/([^:])(.*:)([^:])/\3\2\1/g'

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 -r '20,$s/(.*)/aaa:\1/g'

awk练习题

用awk 打印整个test.txt (以下操作都是用awk工具实现,针对test.txt)

查找所有包含 ‘bash’ 的行

用 ‘:’ 作为分隔符,查找第三段等于0的行

用 ‘:’ 作为分隔符,查找第一段为 ‘root’ 的行,并把该段的 ‘root’ 换成 ‘toor’ (可以连同sed一起使用)

用 ‘:’ 作为分隔符,打印最后一段

打印行数大于20的所有行

用 ‘:’ 作为分隔符,打印所有第三段小于第四段的行

用 ‘:’ 作为分隔符,打印第一段以及最后一段,并且中间用 ‘@’ 连接 (例如,第一行应该是这样的形式 'root@/bin/bash‘ )

用 ‘:’ 作为分隔符,把整个文档的第四段相加,求和

1: awk '{print $0}' test.txt

2: awk '/bash/ {print $0}' test.txt

3: awk -F ':' '$3==0 {print $0}' test.txt

4: awk -F ':' '$1=="root"'|sed 's/root/toor/g'

5: awk -F ':' '{print $NF}' test.txt

6: awk -F ':' '$NR>20' test.txt

7: awk -F ':' '$3

8: awk -F ':' '{print $1"@"$NF}' test.txt

9: awk -F ':' '{sum=sum+$4};END{print sum}' test.txt

### 回答1: 1. 使用awk命令,将一个文件中的第一列和第二列相加,并输出结果。 2. 使用sed命令,将一个文件中的所有空删除,并输出结果。 3. 使用grep命令,查找一个文件中包含特定字符串的,并输出结果。 4. 使用awk命令,将一个文件中的所有按照第二列进排序,并输出结果。 5. 使用sed命令,将一个文件中的所有单词转换为大写,并输出结果。 6. 使用grep命令,查找一个文件中不包含特定字符串的,并输出结果。 7. 使用awk命令,将一个文件中的所有按照第一列进分组,并输出结果。 8. 使用sed命令,将一个文件中的所有反转,并输出结果。 9. 使用grep命令,查找一个文件中包含特定字符串的数,并输出结果。 10. 使用awk命令,将一个文件中的所有按照第三列进筛选,并输出结果。 ### 回答2: awksedgrepLinux系统中常见的文本处理工具,它们可以对文本进搜索、替换、过滤、格式化等操作。以下是一些常见的练习题,可以帮助读者加深对这些工具的理解和掌握它们的使用技巧。 1. 使用awk命令统计日志文件中每个IP的访问次数。 awk '{a[$1]++} END {for(i in a) print i, a[i]}' logfile 其中,a[$1]++用于统计IP的访问次数,END子句用于在处理完整个文件后输出结果。 2. 使用sed命令批量重命名文件夹中所有的.jpg文件为.png。 sed -i 's/\.jpg/\.png/g' $(find /path/to/folder -type f -name '*.jpg') 其中,-i选项表示直接修改原文件,使用find命令来查找所有.jpg文件,并将其替换为.png。 3. 使用grep命令查找一个目录下所有包含“Linux”关键字的文件,并输出匹配结果。 grep -r "Linux" /path/to/directory 其中,-r选项表示递归查找所有文件,如果找到匹配项,则会输出所在的文件名和匹配的。 4. 使用awk命令从一组数字中找出最大值和最小值,并计算它们的平均数。 echo "1 2 3 4 5" | awk 'BEGIN {max=0;min=999999} {for(i=1;i<=NF;i++) if($i>max) max=$i;else if($i<min) min=$i;total+=$i} END {print "Max:",max,"Min:",min,"Avg:",total/NF}' 其中,BEGIN子句用于初始化max和min变量,NF表示输入的字段数量,END子句用于计算平均数。 以上是关于awksedgrep的基础练习题,掌握了这些基本操作后,读者可以尝试更复杂的文本处理任务,如去重、排序、计数等。同时,多查阅相关文档和资料,不断练习,可以更好地掌握这些工具。 ### 回答3: awksedgrep三者是Linux中常用的文本处理命令,它们都可以用来处理大量的文本信息。下面是一些实践练习。 1. 使用grep 给定一个文件file.txt,其中的每都是一个字符串,找出其中包含字符串“hello”的所有并输出到一个新的文件new.txtgrep "hello" file.txt > new.txt 2. 使用awk 给定一个包含三列的文件file.txt(英语、数学和科学的成绩),找出其中科学成绩大于80分的所有学生。 awk '$3>80{print $0}' file.txt 3. 使用sed 给定一个文件file.txt,其中有若干英文句子,将其中所有的小写字母转换为大写字母。 sed 's/[a-z]/\U&/g' file.txt 4. 使用grepawk 给定一个包含多个文件的目录dir,找出其中含有文件名“error.log”的文件,并统计各个文件中“error”单词出现的总次数。 grep -l "error.log" dir/* | xargs awk '{count +=gsub(/error/,"&")}END{print count}' 以上是一些常用的练习题,可以帮助大家熟悉和掌握这些常用命令的使用方法。需要注意的是,在实践过程中,应该多加尝试,有问及时查阅相关文档或寻求帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值