语法格式:

awk 'BEGIN{}pattern{commands}END{}' file_name

standard output | awk 'BEGIN{}pattern{commands}END{}'

基本格式

awk 'BEGIN{}pattern{commands}END{}'

BEGIN{} 文本处理前所做的处理

pattern{commands} 对文本具体的处理

END{} 文本处理后所做的处理

常用变量

最常用:

$0 整行

$1 首行

$  末行

$NF 通常用于指定最后一个字段

FS 列分隔符(默认为空格)

RS 行分隔符(默认为换行)

NF 有多少列

实例

awk '{print $0}' passwd 输出整行内容

awk 'BEGIN{FS=":"}{print $1}' passwd 输出所有行的第一个字段

awk '{print NF}' passwd 输出每一行的字段个数(多少列)

awk 'BEGIN{RS="--"}{print $0}' list RS 指定行分隔符: --

awk 'BEGIN{RS="--";FS="|"}{print $3}' list 

printf的用法

最常用

%s 字符串格式

%d 十进制格式

%f 浮点数格式

awk 'BEGIN{FS=":"}{printf "%s\n",$1}' passwd 打印字符串,分隔符为":",打印后换行

awk 'BEGIN{FS=":"}{printf "%20s %20s\n",$1,$7}' passwd 加入占位符美化,%20s表示占位20个字符

awk 'BEGIN{FS=":"}{printf "%-20s %-20s\n",$1,$7}' passwd "-"表示左对齐

awk 'BEGIN{FS=":"}{printf "%0.2f\n",$3}' passwd 打印浮点数,小数点后2位(默认小数点后4位)

awk的匹配模式

awk 'BEGIN{FS=":"}/root/{print $0}' passwd 匹配passwd文件行中含有root字符串的所有行

 awk '/^nginx/{print $0}' passwd 匹配passwd文件行中以nginx开头的所有行

运算符匹配

  • < 小于
  • > 大于
  • <= 小于等于
  • >= 大于等于
  • == 等于
  • != 不等于
  • ~ 匹配正则表达式
  • !~ 不匹配正则表达式

awk 'BEGIN{FS=":"}$3<50{print $0}' passwd 以 : 为分隔符,匹配passwd文件中第3个字段小于50的所有行信息

awk 'BEGIN{FS=":"}$7=="/bin/bash"{print $0}' passwd 以:为分隔符,匹配passwd文件中第7个字段为/bin/bash的所有行信息

awk 'BEGIN{FS=":"}$7!="/bin/bash"{print $0}' passwd 以:为分隔符,匹配passwd文件中第7个字段不为/bin/bash的所有行信息

awk 'BEGIN{FS=":"}$3 ~ /[0-9]{3,}/{print $0}' passwd 以:为分隔符,匹配passwd文件中第3个字段包含3个数字以上的所有行信息

布尔运算符匹配

  • || 或
  • && 与
  • ! 非

awk 'BEGIN{FS=":"}$1=="ftp" || $1=="mail"{print $0}' passwd 为分隔符,匹配/etc/passwd文件中包含ftp或mail的所有行信息

awk 'BEGIN{FS=":"}$3<50 && $4>50{print $0}' passwd 以:为分隔符,匹配/etc/passwd文件中第3个字段小于50并且第4个字段大于50的所有行信息

awk 'BEGIN{FS=":"}/^nginx/{print $0}' passwd 匹配包含 nginx开头 的行

awk 'BEGIN{FS=":"}$3==1{print $0}' passwd 关系运算符,uid 等于1的行

awk 'BEGIN{FS=":"}$3~/[0-9]{3,}/{print $0}' passwd 匹配uid(数字)为3位及以上的行

awk 'BEGIN{FS=":"}$0!~/\/sbin\/nologin/{print $0}' passwd 匹配不包含/sbin/nologin 的行

awk 'BEGIN{FS=":"}$3<50 && $7~/\/bin\/bash/ {print $0}' passwd 找出 uid 小于50,且bash为 /bin/bash 的行

语法格式

第一种形式: 基于文件

1
awk 'BEGIN{}pattern{commands}END{}' file_name

  

第二种形式: 基于标准命令格式

1
standard output | awk 'BEGIN{}pattern{commands}END{}'

shell编程:awk基础的更多相关文章

  1. shell编程awk基础介绍

    awk介绍 报告生成器,格式化文本输出 处理机制类似sed命令,自带循环处理    读入一行处理一行然后自动读取下一行再进行处理 sed命令换行的标识是固定的,只能是回车换行.    awk里面的换行 ...

  2. Linux学习笔记(17) Shell编程之基础

    1. 正则表达式 (1) 正则表达式用来在文件中匹配符合条件的字符串,正则是包含匹配.grep.awk.sed等命令可以支持正则表达式:通配符用来匹配符合条件的文件名,通配符是完全匹配.ls.find ...

  3. Shell编程菜鸟基础入门笔记

    Shell编程基础入门     1.shell格式:例 shell脚本开发习惯 1.指定解释器 #!/bin/bash 2.脚本开头加版权等信息如:#DATE:时间,#author(作者)#mail: ...

  4. Shell编程入门基础上

    前言 为什么学 Shell Shell 脚本语言是实现 Linux/UNIX 系统管理及自动化运维所必备的重要工具, Linux/UNIX 系统的底层及基础应用软件的核心大都涉及 Shell 脚本的内 ...

  5. shell编程awk进阶

    awk操作符 算术操作符:  x+y, x-y, x*y, x/y, x^y, x%y      -x: 转换为负数      +x: 转换为数值 字符串操作符:没有符号的操作符,字符串连接 赋值操作 ...

  6. Shell编程——bash基础知识

    # Bash中自动补全时忽略大小写 # 编辑~/.inputrc(没有的话,就新建一个),在最后加一行: set completion-ignore-case on # 若要用方向键Up,Down来搜 ...

  7. 第一部分shell编程1基础知识

    ls etc/init.d/ shell脚本的路径 ls /usr/local/apache2/ ls /usr/local/apache2/bin/apachectl 1. shell特性命令历史 ...

  8. Linux Shell编程 awk命令

    概述 awk是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入(stdin).一个或多个文件,或其它命令的输出.它支持用户自定义函数和动态正则表达式等先进功能,是l ...

  9. shell编程之基础

    1.初探shell #!/bin/bash echo -e 'hello \nworld' 执行结果 echo 是打印输出字符,-e选项是开启转义功能 注意: 在windows下编写的shell脚本直 ...

  10. Shell编程-控制结构 | 基础篇

    if-then-else分支结构 if-then-else是一种基于条件测试结果的流程控制结构.如果测试结果为真,则执行控制结构中相应的命令列表:否则将进行另外一个条件测试或者退出该控制结构. if- ...

随机推荐

  1. Spark Streaming 单词计数

    Receiver 从数据源接收数据,然后把数据存储在内存中供spark streaming使用,在本地运行spark streaming不能设置master为local或者local[1],此时运行的 ...

  2. <input>/<textarea>输入框设置默认提示文字(隐藏式)

    html代码如下: <tr>    <td>签   名:</td>    <td><input type="text" nam ...

  3. JSP学习(4)

    JSP学习(4) JavaBean简介 符合某种规范的Java类.使用JavaBean的好处是解决了代码重复编写,减少代码冗余,功能区分明确,提高代码的可维护性 JavaBean设计原则 JSP动作元 ...

  4. linux配置 sudo 授权管理

    为什么使用 sudo,如果普通用户使用 su - root 切换到管理员.进行非法操作,比如 passwd root 修改 root 密码.那么系统其他用户将无法访问系统.这个普通管理员说白了,已经” ...

  5. 完整项目:网上图书商城(一、MySQL数据库设计)未完

    一.建立数据库 CREATE DATABASE IF NOT EXISTS bookshop CHARACTER utf8; 二.建立数据库表 1.建立用户表 #用户表(用户id号,用户名,用户密码, ...

  6. HttpClientUtil工具类封装

    package com.jd.ng.shiro.utils; import org.apache.http.HttpEntity; import org.apache.http.HttpStatus; ...

  7. 【leetcode】1026. Maximum Difference Between Node and Ancestor

    题目如下: Given the root of a binary tree, find the maximum value V for which there exists different nod ...

  8. ht-1 jdk calendar类

    package calendardemo; import java.util.Calendar; public class CalendarDemo { /** * @param args */ pu ...

  9. 如何安装 mcrypt

    #cd libmcrypt-2.5.8 #./configure #make #make install 说明:libmcript默认安装在/usr/local3.安装mhash #tar -zxvf ...

  10. SQL Server数据库的软硬件性能瓶颈

    在过去十年里,很多复杂的企业应用都是用Microsoft SQL Server进行开发和部署的.如今,SQL Server已经成为现代业务应用的基石,并且它还是很多大公司业务流程的核心.SQL Ser ...