sed_find_awk_grep刷题

本文精选了一系列Unix命令的实用技巧,包括文件搜索、文本处理、数据统计等方面,旨在提升用户在Unix环境下的工作效率。涵盖了grep、awk、sed等常用工具的具体应用场景,适合各水平的Unix用户学习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 填空

Unix中在当前目录下所有.cc 的文件中找到含有“asiainfo”内容的文件,命令为:

grep 'asiainfo' file

使用AWK指定分隔符的参数是 -F

awk -F
  1. 简答
    找出当前目录下包含127.0.0.1关键字的文件?
grep '127.0.0.1' files

删除/显示1.txt文件第3行到第10行的内容?

sed -n '3,10p' file

使用awk取出/etc/passwd第一列数据也就是取出用户名。

awk '{print $1}' /etc/passwd

用命令行更改config.txt文件,把里面所有的“name”更改为“address”

sed -i 's/name/address/g' config.txt

写出查询file.txt以abc结尾的行

egrep 'abc$' file.txt
sed -n '/abc^/p' file.txt

删除file.txt文件中的空行

sed -e '/^$/d'

打印file.txt文件中的第10行

sed -n -e '10p'

删除/etc/fstab文件中所有以#开头的行的行首的# 号及#后面的所有空白字符;

sed -e '/^#/s/[#[:space:]]//g' file

查找最后创建时间是3天前,后缀是*.log的文件并删除(三种方法):

方法1:find . -ctime 3 -name '*.sql' --exec rm -f
方法2: find . -ctime 3 -name '*.sql' | xargs rm -f
??方法3:find . -name '*.sql' | awk '{system("ls -irtlh "$1)}' | awk '{print $7,$8,$9}'

使用sed命令打印出文件的第一行到第三行

sed -n  '1,3p'

在/var/sync/log/cef_watchd-20080424.1og文件中查找大小写不敏感“mysql"字符串中的命令是

grep -i 'bin' t.txt

为了在/var/sync/log 目录中查找更改时间在5日以前的文件井删除它们,linux命令是

把data目录及其子目录下所有以扩展名.txt结尾的文件中包含oldgirl的字符串全部替换为oldboy.

```bash
grep -r 's/lodgirl/oldboy' *.txt

写出删除abc.txt文件中的空行

查看linux服务器ip的命令,同时只显示包含ip所在的行打印出来

```bash
ifconfig | egrep '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}'

有文件file1
请用shell查询file1里面空行的所在行号

egrep -n '/^$/p' t.txt

查询file1以abc结尾的行

egrep 'www$' t.txt

打印file文件第一行到第三行

sed -n '1,3p' file

显示file文件里匹配foo字串那行以及上下5行、显示foo及前5行、显示foo及后5行

grep -C 5 'foo' file
grep -A 5 'foo' file
grep -B 5 'foo' file

当前系统中没有任何文本编辑器(vi,emacs,vim,edit等),如何过来掉注释行和空行查看/etc/ssh/sshd_config文件
例如:文件名为“filename”,文件内容如下:

sed -n '/^[^$|#]/p ' t.txt

#This is a comments-1

#This is a comments-2
This is a comments-1
This is a comments-2

This is a comments-3

This is a comments-4

查找file.log文件中的包含关键字“helloworld”的内容,及其上下两行的内容从定向保存到1.txt。请写出命令

grep 'hellworld' file.log > 1.txt
echo "ABCDEF abtdefg" |sed -i s/c/t/g 这条命令是否正确?如若正确可能会显示什么样的结果?

不正确,

查找文件中1到20行之间,同时将"aaa"替换为"AAA",“ddd"替换"DDD”

sed -i '1,20s/aaa/AAA/;s/ddd/DDD/' t.txt

用awk获取文件中第三行的倒数第二列字段

echo 'a,b,c,d,e,f,d' | awk -F"," '{print $(NF-3)}'

二. 进阶题目:

需要用到awk数组和函数知识点

利用sed命令将test.txt中所有的回车替换成空格?

sed 's/\n/ /' file

找出ifconfig命令结果中的1-255之间的数值;

ifconfig | egrep -o '[1-9]{1,3}' | awk ' $1>0 && $1 <= 255{print $1}'

文件内容排序、文件行取唯一值的命令分别是?

sort & uniq

用awk获取文件中第三行的倒数第二列字段

awk是一个很强大的文本处理工具,请使用awk统计当前主机的并发访问量
ss -n | awk '{print $6}' | awk -F":" '{a[$1]++} END{print length(a)}'

??

有一个文件nginx.log,请用awk提取时间(HH:MM),文件内容如下:
183.250.220.178|-l[20/jul/2017:10:35:14 +0800]|POST /audiosearch/search
HTTP/1.1|200|54|-lDalvik/1.6.0(linux;U;Android 4,4,4;Konka Android TV 638
Build/KTU84P)|-l-[5.069|5.001,0.005|www.kuyun.com|8771|172.21.19.67:8084,172.21.19.66:8084]
183.250.220.178|-l[20/jul/2017:10:35:14 +0800]|POST /audiosearch/search
HTTP/1.1|200|54|-lDalvik/1.6.0(linux;U;Android 4,4,4;Konka Android TV 638
Build/KTU84P)|-l-[5.069|5.001,0.005|www.kuyun.com|8771|172.21.19.67:8084,172.21.19.66:8084]

从a.log文件中提取包含“WARNING”或“FATAL”,同时不包含“IGNOR”行,然后,提取以“:”分割的第五个字段

cat a.log egrep 'WARNING|FATAL' | grep -v 'IGNOR' | awk -F":" '{print $5}'

三. 老牛逼题目

统计apache访问日志流量排名前10个IP

统计出apache的access.log 中访问最多的5个ip
这条linux命令的含义:netstat -n |awk ‘/^tcp/ {++h{$NF}} END {for{a in h } print a,h[a] }’
使用awk分析日志(最后一个字段是IP,统计访问量前十的IP,并进行排序)
四.其他笔试题 面试题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值