[面试题]老男孩教育-三剑客笔试题集合

一. 三剑客-基础部分题目

涉及到三剑客过滤,替换,取列操作

1. 选择

在给定文件中查找与条件相符字符串的命令及查找某个目录下相应文件的命令为:(多选)(AC)

  • A:grep
  • B:gzip
  • C:find

sort在给定文件中查找与设定条件相符字符串的命令为(A)

  • A:grep
  • B:gzip
  • C:find
  • D:sort

(cut)命令可以从文本文件的每一行中截取指定内容的数据。

  • A:cp 复制
  • B:dd
  • C:fmt
  • D:cut

下面表述错误的是(D)

  • \ ^表示开头,如^abc表示以abc开头的
  • $表示结尾如abc$表示以abc为结尾的
  • ?表示前一个字符出现0或1次,如ab?c表示a与c之间可有0或1个b存在
  • + 表示前一个字符出现0或多次。如ab+c表示a与c之间可有0或多个b存在

2. 填空

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

find -type f -name ".cc"| xargs grep 'asiainfo'
find -type f -name '
.cc' -exec grep 'asiainfo' {} ;
grep 'asiainfo' `find -type f -name '*.cc' `

如果不指定文件名的话还可以用
grep -rl 'asiainfo'

使用awk指定分隔符的参数是(-F)

awk -F: '{print 1,2}'
awk -vFS=":" '{print 1,3}'
awk 'BEGIN{FS=":"}{print 1,3}'

3. 简答

找出当前目录下包含127.0.0.1关键字的文件?

find . -type f |xargs grep '127.0.0.1'
find . -type f -exec grep '127.0.0.1' {} ;
grep '127.0.0.1' find . -type
sed -n '/127.0.0.1/' find . -type
awk '/127.0.0.1/' find . -type

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

删除

sed -n '3,10!p' 1.txt
sed '3,10d' 1.txt
awk 'NR<3||NR>10' 1.txt
awk '!(NR>=3&&NR<=10)' 1.txt

显示

sed -n '3,10p' 1.txt
awk 'NR>=3&&NR<=10' 1.txt
head 1.txt|tail -n8
awk 'NR==3,NR==10' 1.txt

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

基础必会

awk -F: '{print 1}' /etc/passwd sed 's#:.*##g' /etc/passwd
egrep -o '^[0-Z]+' /etc/passwd
提升
egrep -o '[:]+' /etc/passwd
sed -r 's#([:]+).#\1#g' /etc/passwd
awk '{gsub(/:.
/,"");print}' /etc/passwd awk '{gsub(/:.*/,"")}2' /etc/passwd

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

sed 's#name#address#g' config.txt
awk '{gsub(/name/,"address");print}' config.txt

vim里面进行替换

:%s#name#address#g

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

最后写

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

grep 'abc' file.txt sed -n '/abc/p' file.txt
awk '/abc$/' file.txt

说明;
awk还可以精确到某一列

awk 'NF~/bash/' /etc/passwd
awk 'NR==0' /etc/passwd

删除file.txt文件中的空行

模拟环境

echo -e 'oldboy\noldboy\n\nalex\n    \nalex\nlidao  lidao  alex\n  oldboy\n\noldboyedu group 598972270' >file.txt

最终效果

[root@oldboy ~]# cat -A file.txt
oldboy$
oldboy$
$
alex$
    $
alex$
lidao  lidao  alex$
  oldboy$
$
oldboyedu group 598972270$

只过滤掉空行

grep -v '^' file.txt sed '/^/d' file.txt
sed -n '/^/p' file.txt awk '!/^/' file.txt

题目中所说得过滤掉空行有可能还包括只有空格的行

egrep -v '^|^ +' file.txt
sed -n '/^ */!p' file.txt sed '/^ */d' file.txt
awk '!/^ */' file.txt 如果文件中包含tab键可以用 sed '/^[ \t]*/d' file.txt

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

sed -n '10p' file.txt
awk 'NR==10' file.txt
head file.txt|tail -n1

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

sed 's@#[[:space:]]*@@;//d' /etc/fstab sed -r 's/^[# ]+//g;/^/d' /etc/fstab
sed -r '/#/s@#|[ \t]+@@g&&s#^$##g' /etc/fstab
awk '/#/{gsub(/#|[ \t]+/,"")}1' /etc/fstab

查找最后创建时间是3天前,后缀是*.log的文件并删除

首先假设是在oldboy目录下,面试的时候面试哪家写哪家

第一种方法

find . -mtime +3 -name '.log' |xargs rm -rf
find . -mtime +3 -name '
.log' |xargs -i rm -r {}

第二种方法

rm -rf $(find . -mtime +3 -name '*.log')
rm -rf find . -mtime +3 -name '*.log'

第三种方法

find . -mtime +3 -name '*.log' -exec rm -rf {} \;
形式-exec find 命令查找出文件会一次一个的放到{}里

第四种方法

find . -mtime +3 -name '*.log' -exec rm -rf {} +
find 命令查找出文件会一次性的放到{}里

第五种方法

find . -mtime +3 -name '*.log' -delete
delete表示删除

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

第一个简单思路

❑ sed -n '1,20p' lidao.txt| tr 'ad' 'AD'
❑ awk 'NR==1,NR==20{print toupper(0)}' lidao.txt ❑ awk 'NR>=1&&NR<=20{print toupper(0)}' lidao.txt
❑ sed '1,20s#[ad]#\U&#g' lidao.txt
❑ sed '1,20y/ad/AD/p' lidao.txt
第二个简单大小替换·
tr 'ad' 'AD'
sed 'y#ad#AD#'
sed 's#[ad]#\U&#g'
awk '{print toupper($0)}'

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

sed -n '1,3p' 1.log
head -n3 1.log
awk 'NR<=3' 1.log
awk 'NR>=1&&NR<=3' 1.txt
awk 'NR==1,NR==3' 1.txt

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

grep -i 'mysql' /var/ sync/log/cef_watchd-20080424.1og

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

find /var/sync/log -type f -mtime +5|xargs rm -rf
find /var/sync/log -type f -mtime +5|xargs -i rm -rf {}
find /var/sync/log -mtime +5 -exec rm -rf {} \;
find /var/sync/log -mtime +5 -exec rm -rf {} +
rm -rf $(find /var/sync/log -mtime +5)
rm -rf `find /var/sync/log -mtime +5`
find /var/sync/log -mtime +5 -delete

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

find data -type f -name '*.txt'|xargs sed -i 's#oldgirl#oldboy#g'
sed 's#oldboy#oldgril#g' `find -type f -name "*.txt"
sed 's#oldboy#oldgril#g' $(find -type f -name "*.txt")
find -type f -name “*.txt” -exec sed ‘s#oldboy#oldgirl#g’ {} \;
find -type f -name “*.txt” -exec sed ‘s#oldboy#oldgirl#g’ {} +
find -type f -name “*.txt” -exec awk '{gsub(/oldboy/,"oldgirl")}1 ' {}'

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

简单思路只删除空行
sed -i '/^$/d' abc.txt
sed -i '/^$/!p' abc.txt````awk '!/^/' abc.txt``` ```grep -v '^ ' abc.txt```
如果文件中还包含只有空格的行

egrep -v '^|^ *' file.txt
sed '/^ */d' file.txt awk '!/^ */' file.txt

如果还包含tb键

sed '/^[ \t]*/d' file.txt awk '!/^[ \t]*/' file.txt

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

ip a s eth0|awk -F'[ /]+' 'NR==3{print 3}' hostname -I ip a s eth0|sed -rn '3s#^.*t (.*)/.*#\1#gp'

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

awk 'NR=3{print $(NF-1)}' sed.txt

有文件file1

  • 请用shell查询file1里面空行的所在行号
    grep -n '^$' file 1
    awk '/^$/{print NR,$0}' file1
  • 查询file1以abc结尾的行
    grep 'abc$' file 1
    sed -n '/^$/p' file1
    sed '/abc$/d' file1
    awk '/abc$/' file1
  • 打印file文件第一行到第三行

sed '1,3p' file 1
awk 'NR==1,NR==3{print}' file 1
awk 'NR>=1&&NR<=3{print}' file 1

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

grep -C5 'foo' file
grep -B5 'foo' file
grep -A5 'foo' file

echo "ABCDEF abtdefg" |sed -i s/c/t/g 这条命令是否正确?如若正确可能会显示什么样的结果?

不正确,-i是修改文件内容

[root@oldboy ~]# echo "ABCDEF abtdefg" |sed -i s/c/t/g
sed: no input files

无法找到要修改的文件

当前系统中没有任何文本编辑器(vi,emacs,vim,edit等),如何过滤掉注释行和空行查看/etc/ssh/sshd_config文件

awk '!/^$|^#/' /etc/ssh/sshd_config
egrep -v '^$|^#' /etc/ssh/sshd_config
sed -nr '/^$|^#/!p' /etc/ssh/sshd_config
sed -r '/^$|^#/d' /etc/ssh/sshd_config

例如:文件名为“filename”,文件内容如下:

#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 -C2 'helloworld' file.log >1.txt

二. 进阶题目:

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

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

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

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

awk 'NR=3{print $(NF-1)}' oldboy.txt

awk是一个很强大的文本处理工具,请使用awk统计当前主机的并发访问量

有一个文件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]

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

统计出apache的access.log 中访问最多的5个ip

这条linux命令的含义:netstat -n |awk '/^tcp/

使用awk分析日志(最后一个字段是IP,统计访问量前十的IP,并进行排序)

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值