• AWK 命令


    入门实例

    last -n 5 仅取出前五行
    root     pts/1   192.168.1.100  Tue Feb 10 11:21   still logged in
    
    root     pts/1   192.168.1.100  Tue Feb 10 00:46 - 02:28  (01:41)
    
    root     pts/1   192.168.1.100  Mon Feb  9 11:41 - 18:30  (06:48)
    
    dmtsai   pts/1   192.168.1.100  Mon Feb  9 11:41 - 11:41  (00:00)
    
    root     tty1                   Fri Sep  5 14:09 - 14:10  (00:01)
    

    如果只是显示最近登录的5个帐号

    #last -n 5 | awk  '{print $1}'
    
    root
    
    root
    
    root
    
    dmtsai
    
    root
    

    awk工作流程是这样的:读入有’n’换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。默认域分隔符是”空白键” 或 “键”,所以$1表示登录用户,$3表示登录用户ip,以此类推。

    显示/etc/passwd的账户
    #cat /etc/passwd |awk  -F ':'  '{print $1}'  
    
    root
    
    daemon
    
    bin
    
    sys
    

    这种是awk+action的示例,每行都会执行action{print $1}。

    -F指定域分隔符为’:’。

    显示/etc/passwd的账户和账户对应的shell,而账户与shell之间以tab键分割
    #cat /etc/passwd |awk  -F ':'  '{print $1"	"$7}'
    
    root    /bin/bash
    
    daemon  /bin/sh
    
    bin     /bin/sh
    
    sys     /bin/sh
    
    如果只是显示/etc/passwd的账户和账户对应的shell,而账户与shell之间以逗号分割,而且在所有行添加列名name,shell,在最后一行添加”blue,/bin/nosh”。
    cat /etc/passwd |awk  -F ':'  'BEGIN {print "name,shell"}  {print $1","$7} END {print "blue,/bin/nosh"}'
    
    name,shell
    
    root,/bin/bash
    
    daemon,/bin/sh
    
    bin,/bin/sh
    
    sys,/bin/sh
    
    ....
    
    blue,/bin/nosh
    

    awk工作流程是这样的:先执行BEGING,然后读取文件,读入有/n换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域,随后开始执行模式所对应的动作action。接着开始读入第二条记录······直到所有的记录都读完,最后执行END操作。

    搜索/etc/passwd有root关键字的所有行
    #awk -F: '/root/' /etc/passwd
    
    root:x:0:0:root:/root:/bin/bash
    

    这种是pattern的使用示例,匹配了pattern(这里是root)的行才会执行action(没有指定action,默认输出每行的内容)。

    搜索支持正则,例如找root开头的: awk -F: ‘/^root/’ /etc/passwd

    搜索/etc/passwd有root关键字的所有行,并显示对应的shell
    # awk -F: '/root/{print $7}' /etc/passwd            
    
    /bin/bash
    

    这里指定了action{print $7}

    awk内置变量

    awk有许多内置变量用来设置环境信息,这些变量可以被改变,下面给出了最常用的一些变量。

    ARGC 命令行参数个数

    ARGV 命令行参数排列

    ENVIRON 支持队列中系统环境变量的使用

    FILENAME awk浏览的文件名

    FNR 浏览文件的记录数

    FS 设置输入域分隔符,等价于命令行 -F选项

    NF 浏览记录的域的个数

    NR 已读的记录数

    OFS 输出域分隔符

    ORS 输出记录分隔符

    RS 控制记录分隔符

    此外,$0变量是指整条记录。$1表示当前行的第一个域,$2表示当前行的第二个域,……以此类推

    统计/etc/passwd:文件名,每行的行号,每行的列数,对应的完整行内容:
    #awk  -F ':'  '{print "filename:" FILENAME ",linenumber:" NR ",columns:" NF ",linecontent:"$0}' /etc/passwd
    
    filename:/etc/passwd,linenumber:1,columns:7,linecontent:root:x:0:0:root:/root:/bin/bash
    
    filename:/etc/passwd,linenumber:2,columns:7,linecontent:daemon:x:1:1:daemon:/usr/sbin:/bin/sh
    
    filename:/etc/passwd,linenumber:3,columns:7,linecontent:bin:x:2:2:bin:/bin:/bin/sh
    
    filename:/etc/passwd,linenumber:4,columns:7,linecontent:sys:x:3:3:sys:/dev:/bin/sh
    
    使用printf替代print,可以让代码更加简洁,易读
    awk  -F ':'  '{printf("filename:%10s,linenumber:%s,columns:%s,linecontent:%sn",FILENAME,NR,NF,$0)}' /etc/passwd
    

    print和printf

    awk中同时提供了print和printf两种打印输出的函数。

    其中print函数的参数可以是变量、数值或者字符串。字符串必须用双引号引用,参数用逗号分隔。如果没有逗号,参数就串联在一起而无法区分。这里,逗号的作用与输出文件的分隔符的作用是一样的,只是后者是空格而已。

    printf函数,其用法和c语言中printf基本相似,可以格式化字符串,输出复杂时,printf更加好用,代码更易懂。

  • 相关阅读:
    selenium3+python自动化9-JS增加、删除、修改HTML元素属性
    selenium3+python自动化8-JS处理滚动条 (2020-02-14 17:35)
    在sql server使用链接服务器中访问mysql
    C# 软件绑定QQ群类开源放出
    时间段控制代码
    C# Aspose.Words.Document.PageCount 踩坑笔记(获取文档页数)
    Sql Server日期转汉字字符串
    C#调用WPS转换文档到PDF的的实现代码。
    SocketException 不知道这样的主机(Quartz.;Dns.GetHostEntry;new HttpChannel)问题记录
    SqlServer 联合Update
  • 原文地址:https://www.cnblogs.com/kcxg/p/11075854.html
Copyright © 2020-2023  润新知