awkのファイル処理

簡単な紹介

awk 是逐行扫描文件(从第1行到最后一行),寻找含有目标文本的行:
    如果匹配成功,则会在该行上执行用户想要的操作。
    反之,则不对行做任何处理。

awk 命令的基本格式为:
    awk [选项] '脚本命令' 文件名

awkのオプション

-F';'
    指定以 ; 作为输入行的分隔符,awk 命令默认分隔符为空格或制表符。

-f file
    从脚本文件中读取 awk 脚本指令,以取代直接在命令行中输入指令。

-v var=val
    在执行处理过程之前,设置一个变量 var,并给其设备初始值为 val。

基本的な使用

awk 的强大之处在于脚本命令,它由2部分组成,分别为匹配规则和执行命令,如下所示:
    '匹配规则{执行命令}'

匹配规则,可以使用字符串(比如 /demo/,表示查看含有 demo 字符串的行)或者正则表达式指定。

另外需要注意的是,整个脚本命令是用单引号 '' 括起,而其中的执行命令部分需要用大括号 {} 括起来。

在 awk 程序执行时,如果没有指定执行命令,则默认会把匹配的行输出;
如果不指定匹配规则,则默认匹配文本中所有的行。


awk -F',' '{print $1 "\t" $2}' ld
    以,分割,匹配所有文本,打印第一列和第二列,中间以制表符分割。

awk -F',' '{print $1 , $2}' ld
    以,分割,匹配所有文本,打印第一列和第二列,中间以空格分割(,打印以空格分割)。

awk 'BEGIN{print "666"} END{print "8888"}' ld
    在开头和结尾打印666和8888。

awk -F',' '/12[1]/{print $1 "\t" $2}' ld
    匹配到的行才打印。

awk 'END{print NR}' filename
    打印文本文件的总行数

awk 'NR==1{print}' filename
    打印文本第一行

おすすめ

転載: www.cnblogs.com/loveer/p/11622194.html