• awk中的NR,FNR ,NF,$NF,RS,ORS,FS,OFS


    NR: Numner of Record 所有文件行累计数

    FNR: File Numner of Record 单个文件行累计数

    NF: Number of Field 字段数

    RS:Record Separator 记录行分隔符

    ORS:Output Record Separate 输出行分隔符

    FS:Field Separator 字段分隔符

    OFS:Out of Field Separator 输出的字段分隔符

    NR表示从awk开始执行后,按照记录分隔符读取的数据次数,默认的记录分隔符为换行符,因此默认的就是读取的数据行数,NR可以理解为Number of Record的缩写。

      在awk处理多个输入文件的时候,在处理完第一个文件后,NR并不会从1开始,而是继续累加,因此就出现了FNR,每当处理一个新文件的时候,FNR就从1开始计数,FNR可以理解为File Number of Record。

      NF表示目前的记录被分割的字段的数目,NF可以理解为Number of Field。

    下面以示例程序来进行说明,首先准备两个输入文件class1和class2,记录了两个班级的成绩信息,内容分别如下所示:

    $ cat class1
    zhaoyun 85 87
    guanyu 87 88
    liubei 90 86$ cat class2
    caocao 92 87 90
    guojia 99 96 92

    现在要查看两个班级的所有成绩信息,并在每条信息前加上行号,则可以使用下面的awk指令;

    $ awk '{print NR,$0}' class1 class2
    1 zhaoyun 85 87
    2 guanyu 87 88
    3 liubei 90 86
    4 caocao 92 87 90
    5 guojia 99 96 92

    这里的行号就是通过NR来实现的,awk每读取一条记录,NR的值便加一。如果要求每个班级的行号从头开始变化,则需要使用FNR来实现,如下:

    $ awk '{print FNR,$0}' class1 class2
    1 zhaoyun 85 87
    2 guanyu 87 88
    3 liubei 90 86
    1 caocao 92 87 90
    2 guojia 99 96 92

    下面的示例结合awk内建变量FILENAME,显示出来的两个班级的成绩信息可以进行更好的区分;

    $ awk '{print FILENAME,"NR="NR,"FNR="FNR,"$"NF"="$NF}' class1 class2
    class1 NR=1 FNR=1 $3=87
    class1 NR=2 FNR=2 $3=88
    class1 NR=3 FNR=3 $3=86
    class2 NR=4 FNR=1 $4=90
    class2 NR=5 FNR=2 $4=92

    除了NR和FNR外,上面的示例中还演示了NF的使用,class1中每行有3个字段,而class2中有4个字段,通过$NF就可以很方便的获取最后一个字段了。

    awk下面的变量NF和$NF有什么区别?

    看到awk的时候: {print NF} 也有{print $NF}
           前者是输出了域个数,后者输出每行最后一个域的内容

  • 相关阅读:
    商户网站使用第三方支付的大致原理和实现
    ASP.NET MVC中检测浏览器版本并提示下载更新
    如何选择使用IEnumerable, ICollection, IList
    IEnumerable和IQueryable的区别以及背后的ExpressionTree表达式树
    IEnumerable是集合,IEnumerator是集合的迭代器
    ASP.NET MVC中使用Session来保持表单的状态
    在ASP.NET MVC中实现Select多选
    总结ASP.NET MVC视图页使用jQuery传递异步数据的几种方式
    在ASP.NET MVC4中使用Quartz.NET执行定时任务
    委托, 泛型委托,Func<T>和Action<T>
  • 原文地址:https://www.cnblogs.com/zhangqingsh/p/3040801.html
Copyright © 2020-2023  润新知