zoukankan      html  css  js  c++  java
  • awk

    awk的语法:
    awk [-F re] [parameter...] ['program'] [-f 'programfile'] [in_file_list]

    awk里面的BEGIN,END结构:
    BEGIN和END中的语句分别在开始读取文件(in_file)之前和读取完文件之后发挥作用,可以理解为初始化和扫尾。

    awk里面的if..else;   while ; do..while; for; break; continue; printf 语法都和C语言的语法一致;而且awk支持使用if (key in array)这样的判断语句(其中,array是数组,这一点和python的语法非常相像。);awk支持使用for (key in array)这样的语法来遍历数组(也是和python的语法很相像。)

     

    -F re:允许awk更改其字段分隔符
    -v var=val 把val值赋值给var(变量通信的好方法啊~~今天才知道这个选项,想想之前写的代码,抓狂啊~~)如果有多个变量要赋值,那么就写多个-v,每个变量赋值对应一个-v
    e.g. 要打印文件a的第num行到num+num1行之间的行, awk -v num=$num -v num1=$num1 'NR==num,NR==num+num1{print}' a
    -f progfile:允许awk调用并执行progfile程序文件,当然progfile必须是一个符合awk语法的程序文件

     

    我会用的awk内置变量:
    ARGC    命令行参数的个数
    ARGV:命令行参数数组
    ARGIND 当前被处理文件的ARGV标志符
    e.g 有两个文件a 和b
    awk '{if(ARGIND==1){print "处理a文件"} if(ARGIND==2){print "处理b文件"}}' a b
    文件处理的顺序是先扫描完a文件,再扫描b文件

    NR 已经读出的记录数
    FNR   当前文件的记录数

    上面的例子也可以写成这样:
    awk 'NR==FNR{print "处理文件a"} NR > FNR{print "处理文件b"}' a b
    输入文件a和b,由于先扫描a,所以扫描a的时候必然有NR==FNR,然后扫描b的时候,FNR从1开始计数,而NR则接着a的行数继续计数,所以NR > FNR

    e.g 要显示文件的第10行至第15行
    awk 'NR==10,NR==15{print}' a

    FS 输入字段分隔符(缺省为:space:),相当于-F选项
    awk -F ':' '{print}' a    和   awk 'BEGIN{FS=":"}{print}' a 是一样的

    OFS输出字段分隔符(缺省为:space:)
    awk -F ':' 'BEGIN{OFS=";"}{print $1,$2,$3}' b
    如果cat b为
    1:2:3
    4:5:6
    那么把OFS设置成";"后就会输出
    1;2;3
    4;5;6
    (小注释:awk把分割后的第1、2、3个字段用$1,$2,$3...表示,$0表示整个记录(一般就是一整行))

     

    NF:当前记录中的字段个数
    awk -F ':' '{print NF}' b的输出为
    3
    3
    表明b的每一行用分隔符":"分割后都3个字段
    可以用NF来控制输出符合要求的字段数的行,这样可以处理掉一些异常的行
    awk -F ':' '{if (NF == 3)print}' b

    RS:输入记录分隔符,缺省为" "
    缺省情况下,awk把一行看作一个记录;如果设置了RS,那么awk按照RS来分割记录
    例如,如果文件c,cat c为
    hello world; I want to go swimming tomorrow;hiahia
    运行 awk 'BEGIN{ RS = ";" } {print}' c 的结果为
    hello world
    I want to go swimming tomorrow
    hiahia

     

  • 相关阅读:
    grep命令
    Linux下tar.xz结尾的文件的解压方法
    const char*, char const*, char*const的区别
    "undefined reference to" 多种可能出现的问题解决方法
    Linux查找含有某字符串的所有文件
    Netbeans C++ unable to resolve identifier 无法解析标识符
    Linux 下编译C程序的全过程
    linux tar.gz zip 解压缩 压缩命令
    安装anaconda
    Mongodb数据迁移步骤
  • 原文地址:https://www.cnblogs.com/osly/p/3770294.html
Copyright © 2011-2022 走看看