1.sed
使用sed替换文件中的所有相关内容,例如,把所有的abcd 替换为ABCD
-i 表示操作的是文件,将文件中所有的abcd替换为ABCD
sed -i s/abcd/ABCD/g 2.txt
2.grep
查找并替换当前文件夹下的所有文件,将所有文件中的abcd替换为ABCD
sed -i s/abcd/ABCD/g `grep abcd -rl --include="*.txt" ./`
-r 表示查找所有子目录
-l 表示仅列出符合条件的文件名,用来传给sed命令做操作
–include="*.txt" 表示仅查找txt文件
./ 表示要查找的根目录为当前目录
如果不需要查找子目录,仅需要在当前目录替换,用sed命令就行了,命令如下:
sed -i s/xxxx/yyyy/g ./*.txt
3.使用Linux命令找出日志文件中访问量最大的top10 IP地址
cat test.log|awk -F" " '{print $2}'|sort|uniq -c|sort -nrk 1 -t' '
|awk -F" " '{print $2}'|head -10
问题剖析:
1.cat *.log将文本内容打印到屏幕
2.使用awk命令可以按照分割符将一行分割为多个列,第一列用$1表示,第二列用$2表示,依次类推
awk -F" " '{print $2} //表示用空格作为分隔符进行分割,打印出第2列
3.sort 进行排序,默认是按照ascii码进行排序的
4.uniq -c 统计相邻的行的重复数量,结果是类似 3 127.13.13.13,前面的数字代码重复的行数
sort|uniq -c //统计重复的行数
5.sort -n是按照数值进行由小到大进行排序, -r是表示逆序,-t是指定分割符,-k是执行按照第几列进行排序
sort -nrk 1 -t' '
6.使用awk命令可以按照分割符将一行分割为多个列,第一列用$1表示,第二列用$2表示,依次类推
awk -F" " '{print $2}' //表示用空格作为分隔符进行分割,打印出第2列
7.head -n表示取前n个
head -10
4.查看文件的第10-20行
head -n 200 filename | tail -n 100