摘要:awk 是 Linux 中强大的文本处理工具,除了基本用法外,还有许多高级功能。以下是一些常见的高级用法:
awk 是 Linux 中强大的文本处理工具,除了基本用法外,还有许多高级功能。以下是一些常见的高级用法:
awk 提供了多个内置变量,如 NR(当前记录号)、NF(当前记录的字段数)、FS(字段分隔符)等。
示例:打印文件行号及内容awk '{print NR, $0}' file.txt示例:打印每行的最后一个字段awk '{print $NF}' file.txt通过 -F 选项或 FS 变量,可以指定字段分隔符。
示例:使用逗号作为分隔符awk -F, '{print $1, $2}' file.csv示例:在脚本中设置分隔符awk 'BEGIN {FS=","} {print $1, $2}' file.csvawk 支持 if-else 等条件语句,用于根据条件处理数据。
示例:打印第一字段大于 10 的行awk '{if ($1 > 10) print $0}' file.txt示例:根据条件输出不同内容awk '{if ($1 > 10) print "High"; else print "Low"}' file.txtawk 支持 for 和 while 循环,适合处理数组或重复操作。
示例:打印每行的所有字段awk '{for (i=1; i示例:计算字段总和awk '{sum=0; for (i=1; iawk 支持关联数组,适合统计和分组操作。
示例:统计字段出现次数awk '{count[$1]++} END {for (item in count) print item, count[item]}' file.txt示例:按字段分组求和awk '{sum[$1]+=$2} END {for (item in sum) print item, sum[item]}' file.txtawk 提供了多种内置函数,如 length、substr、gsub 等。
示例:计算每行长度awk '{print length($0)}' file.txt示例:替换字符串awk '{gsub(/foo/, "bar"); print $0}' file.txtawk 可以同时处理多个文件,通过 FILENAME 变量获取当前文件名。
示例:打印文件名及内容awk '{print FILENAME, $0}' file1.txt file2.txtBEGIN 和 END 块分别用于在处理前后执行操作。
示例:打印开始和结束信息awk 'BEGIN {print "Start"} {print $0} END {print "End"}' file.txt示例:计算总和awk '{sum+=$1} END {print sum}' file.txtawk 支持将输出重定向到文件。
示例:将输出写入文件awk '{print $0 > "output.txt"}' file.txtawk 支持正则表达式匹配。
示例:匹配包含 "error" 的行awk '/error/ {print $0}' file.txt示例:匹配以数字开头的行awk '/^[0-9]/ {print $0}' file.txt通过设置 RS(记录分隔符),可以处理多行记录。
示例:处理以空行分隔的多行记录awk 'BEGIN {RS=""; FS="\n"} {print $1, $2}' file.txt使用 printf 可以格式化输出。
示例:格式化输出awk '{printf "Name: %-10s Age: %d\n", $1, $2}' file.txt通过 ARGC 和 ARGV 可以访问命令行参数。
示例:打印命令行参数awk 'BEGIN {for (i=0; igetline 用于读取额外行,适合处理复杂文本。
示例:读取下一行并处理awk '{print $0; getline; print $0}' file.txt示例:将二进制字符串转换为十进制awk '{print strtonum("0x" $1)}' file.txt还是那句话:干中学,学中干
如果觉得不错的话,麻烦点个关注,收藏谢谢。
毕竟:
我太想进步了
来源:世道科技圈