最近面试过程中被问到一些linux中文件处理相关的命令,于是整理了一下awk相关的使用
示例1,使用awk统计文件行数
qingsong@db2a:/tmp$ awk "BEGIN { i=0 } { i++ } END{ print i }" access_bak.log
14
示例2,打印文件
awk {print} access_bak.log
示例3,打印文件时加上头和尾:
qingsong@db2a:/tmp$ awk ' BEGIN { print "begin" } {print} END {print "end"}' access_bak.log
awk的特殊变量
NR 当前行号
NF 当前行字段数
$0 当前行的文本
$1 当前行第一个字段
$n 当前行第n个字段
统计行号的另一种方法:
awk "END{ print NR}" access_bak.log
打印第2,4个字段
$ awk '{print $2,$4}' access_bak.log
打印倒数第二个,倒数第一个字段:
$ awk '{print $(NF-1), $NF}' employee.txt
打印第4个字段,以及第4个字段加1000之后的值:
$ awk '{print $4, 1000+$4}' employee.txt
打印第4个字段,以及第4个字段加1000之后的值:
$ awk '{print $4, 1000+$4}' employee.txt
统计第二列的数字之和:
awk 'BEGIN{sum=0} {sum+=$2} END{print sum}' access_log_num.log
awk '$2<33 { print $0}' access_log_num.log
包含22的行:
awk '/22/{print $0}' access_log_num.log
打印从M行到N行的数据
awk "NR=2,NR=4" access_log_num.log
打印出start_pattern和end_pattern之间的文本
$ awk '/start_pattern/, /end_pattern/' filename