当年,我还是Linux菜鸟的时候,就在简历上写着精通Linux命令了,而当面试官问我“如何快速查看某个文件的第200行,仅这一行”时,我的心里是懵逼的。
当时面试官心里估计在窃喜,从我敷衍的回答中,他应该已经完全了解到了我的Linux水平如何[-_-]
不过,不得不说,这是一道非常好的面试题,对于一些只知道cd ls cp rm基础命令的人来说,完全回答不了,而对于真正熟悉Linux人来说,答案信手拈来,下面来看看。
cat -n temp.log | grep -w '^\s*200'
是的,每行前面加个行号,然后grep过滤一下就出来了。
cat temp.log | sed -n '200p'
sed命令能直接用行号匹配,匹配到的行用p指令输出就行了。
cat temp.log | awk 'NR==200'
这个和sed命令类似,不过NR代表行号。
cat temp.log|perl -lne 'print $_ if $.==200'
和awk是类似的,不过语法不同罢了。
cat temp.log | head -n 200 | tail -n1
是的,先取前200行,再用tail取最后一行就可以了,这么简单咋当时想不到呢!
cat temp.log | cut -z -d $'\n' -f200
cat temp.log | awk -F '\n' -v RS='\0' '{print $200}'
嗯,把整个文件内容当成一条记录,把换行符当成列分隔符,取第200列就好了嘛。
cat temp.log | xargs -d'\n' bash -c 'echo $200' -
和上面是类似的,不过这次使用xargs把所有行变成了bash命令的参数,然后打印第200个参数即可。
注:上面没有详细解释各个命令的用法,如果想了解这些命令,可以看看我之前写的两篇文章。
是的,使用Linux命令,实现一个功能,可以有很多种解法,它和普通的编程思维很不一样,只要不把思考方式限定在编程实现上,渐渐地解法都会像灵感一样,从你大脑中蹦出来。