首页 > 其他分享 >2.6.3、awk 命令

2.6.3、awk 命令

时间:2024-04-02 13:32:24浏览次数:28  
标签:脚本 指定 数据字 命令 awk 文本 2.6

关注公众号 “融码一生”,领取全套 PDF / 电子书

  • Linux 系统中还有一个功能更加强大的文本数据处理工具:awk,它诞生于 20 世纪 70 年代末期,这也许是它影响众多 Linux 用户的原因之一。
  • awk 是由 Aho、Weingberger 和 Kernighan 设计开发,因此这 3 为大师姓的首字母即为命令名。
  • 和 sed 命令类似,awk 命令也是逐行扫描文件(从第 1 行到最后一行),寻找含有目标文本的行,如果匹配成功,则会在该行上执行用户想要的操作;反之则不对行做任何处理。基本格式:
    • awk [选项] '脚本命令' 文件名

选项

含义

-F fs

指定以 fs 作为输入行的分隔符(默认为空格或制表符)

-f file

从脚本文件中读取 awk 脚本指令(取代命令行中输入指令)

-v var=val

在执行处理过程之前设置一个变量 var,并设置初始值为 val

  • awk 的强大之处在于脚本命令,它由 2 部分组成:匹配规则、执行命令
    • '匹配规则{执行命令}'
      • 匹配规则和sed命令中的address部分作用相同,用来指定脚本命令可以作用到文本内容中的具体行,可以使用字符串(如/demo/表示查看含有 demo 字符串的行)或正则表达式指定。
      • 整个脚本命令用单引号'括起,而其中的执行命令部分需要用大括号{}括起来。
  • 在 awk 程序执行时,如果没有指定执行命令,则默认会把匹配的行输出;如果不指定匹配规则,则默认匹配文本中所有的行。
  • 示例:
    • awk '/^$/ {print "Blank line"}' test.txt
      • /^$/是一个正则表达式,匹配文本中的空白行
      • 执行命令使用的是 print 命令,将指定的文本进行输出
      • 整个命令的功能:如果test.txt有 N 个空白行,那么执行此命令会输出 N 个 Blank line

1、使用数据字段变量

  • awk 的主要特性之一是其处理文本文件中数据的能力,它会自动给一行中的每个数据元素分配一个变量。awk 默认会将如下变量分配给它在文本行中发现的数据字段:
    • $0:代表整个文本行
    • $1:代表文本行中的第 1 个数据字段
    • $2:代表文本行中的第 2 个数据字段
    • $n:代表文本行中的第 n 个数据字段
  • awk 中默认的字段分隔符是任意的空白字符(如空格、制表符)。 在文本行中,每个数据字段都是通过字段分隔符划分。awk 在读取一行文本时会用预定义的字段分隔符划分每个数据字段。
  • awk 程序读取文本文件,只显示第 1 个数据字段的值:
cat test.txt
:<<!
One line of test text.
Two lines of test text.
Three lines of test text.
!


awk '{print $1}' test.txt
:<<!
One
Two
Three
!
  • 如果要读取采用了其它字段分隔符的文件,可以用-F选项手动指定。

2、awk 脚本命令使用多个命令

  • awk 允许将多条命令组合成一个正常的程序。
  • 要在命令行上的程序脚本中使用多条命令,只要在命令之间放个分号即可:
echo "My name is Rich" | awk '{$4="Christine"; print $0}'
:<<!
My name is Christine
!
  • 第一条命令会给字段变量$4赋值。第二条命令会打印整个数据字段。
  • 可以看到,awk 程序在输出中已经将原文本中的第四个数据字段替换成了新值。
  • 也可以一次一行地输入程序脚本命令:

echo "My name is Rich" | awk '{
$4="Christine"
print $0}'

:<<!
My name is Christine
!
  • 在用了起始的单引号后,bash shell 会使用>来提示输入更多数据,此时可以每次在每行加一条命令,直到输入了结尾的单引号。
  • 注意:如果没有在命令行中指定文件名,awk 程序需要用户输入获得数据,因此当运行这个程序时,会一直等着用户输入文本,此时如果要退出程序,只需按 Ctrl+D 组合键:

awk '{
$4="Christine"
print $0}'

3、从文件中读取程序

  • 跟 sed 一样,awk 允许将脚本命令存储到文件中,然后再在命令行中引用:
cat awk.sh
:<<!
{print $1 "'s home directory is " $6}
!


awk -F: -f awk.sh /etc/passwd
:<<!
root's home directory is /root
bin's home directory is /bin
daemon's home directory is /sbin
adm's home directory is /var/adm
lp's home directory is /var/spool/lpd
sync's home directory is /sbin
shutdown's home directory is /sbin
halt's home directory is /sbin
mail's home directory is /var/spool/mail
operator's home directory is /root
games's home directory is /usr/games
ftp's home directory is /var/ftp
...
!
  • awk.sh脚本文件会使用 print 命令打印/etc/passwd文件的主目录数据字段(字段变量$6),以及userid数据字段(字段变量$1)。
  • 注意:在程序文件中也可以指定多条命令,一条命令放一行即可,之间不需要用分号。

4、BEGIN 关键字

  • awk 中还可以指定脚本命令的运行时机。awk 默认会从输入中读取一行文本,然后针对该行的数据执行程序脚本,但有时可能需要在处理数据前运行一些脚本命令,这就需要使用 BEGIN 关键字。
  • BEGIN 会强制 awk 在读取数据前执行该关键字后指定的脚本命令:

cat test.txt
:<<!
Line 1
Line 2
Line 3
!


awk 'BEGIN {print "The data3 File Contents:"}
{print $0}' test.txt
:<<!
The data3 File Contents:
Line 1
Line 2
Line 3
!
  • 脚本命令中分为 2 部分:
    • BEGIN 部分的脚本指令会在 awk 命令处理数据前运行
    • 真正用来处理数据的是第二段脚本命令

5、END 关键字

  • 和 BEGIN 关键字相对应,END 关键字允许指定一些脚本命令,awk 会在读完数据后执行它们,例如:

cat test.txt
:<<!
Line 1
Line 2
Line 3
!

awk 'BEGIN {print "The test.txt File Contents:"}
{print $0}
END {print "End of File"}' test.txt

:<<!
The test.txt File Contents:
Line 1
Line 2
Line 3
End of File
!
  • 当 awk 程序打印完文件内容后,才会执行 END 中的脚本命令。

关注公众号 “融码一生”,领取全套 PDF / 电子书

标签:脚本,指定,数据字,命令,awk,文本,2.6
From: https://blog.csdn.net/m0_66491750/article/details/137251209

相关文章

  • 磁盘划分命令
    fdiskfdisk-l[设备名]列出系统分区//查看分区情况fdisk设备名//为磁盘或设备分区mkfsmkfs.ext4设备//为设备设置文件系统类型mountmount分区文件挂载点挂载点不能是系统一些重要目录空目录不能被占用umount分区文件umount挂载点dfdf-h/......
  • WEB专项-文件上传&命令执行&SSTI模板注入&其他
    文件上传一、Upload11.进入靶场,是一个文件上传功能的页面,尝试上传一个一句话木马去getshell。2.发现提示是notimage,那就通过burp抓包进行类型的修改。3.但却提示我这个是php代码,看来对文件的后缀名进行了过滤,那就将其后缀名改为jpg。4.又提示我文件中包含<?,那接下来......
  • Linux enable命令教程:启动或关闭shell内建指令(附实例详解和注意事项)
    Linuxenable命令介绍enable是Linux系统中的内建命令,用于启动或关闭shell内建指令。如果执行的文件名称与shell内建指令相同,可以使用enable-n来关闭shell内建指令。如果不加-n参数,enable可以重新启动已关闭的指令。Linuxenable命令适用的Linux版本enable命令在大多数Li......
  • Linux ntsysv命令教程:如何配置运行级别服务(附案例详解和注意事项)
    Linuxntsysv命令介绍ntsysv(NetworkSysV)是一个命令行应用程序,它提供了一个简单的文本用户界面来配置在选定的运行级别中要启动的服务。这个工具显示了可用服务的列表(来自/etc/rc.d/init.d/目录的服务)以及它们的当前状态和描述。Linuxntsysv命令适用的Linux版本ntsysv命......
  • 将wavedrom图转换为excel+UVM使用双顶层环境+慎用casex和casez使用case inside+shell
    将wavedrom图转换为excel原理上是先转换为json,然后写入到excel中。importcsvimportjsonimportpandasaspdcontent=[]withopen("source.txt")asf:c=f.read()c=c.replace("reg","\"reg\"").replace("bits",&......
  • 计算机组成与体系结构--2.6:总线系统,2.7:寻址方式,2.8:CISC与RISC
    转上一节:http://t.csdnimg.cn/3xoZahttp://t.csdnimg.cn/3xoZa2.6:总线系统按照连接对象分为:内总线(又称为系统总线,各功能部件之间的传输通路)和外总线(又称通信总线,是系统之间或是计算机主机与外围设备之间的传输通路)按照通信仿式分为:串行总线(数据按位依次传输)和并行......
  • 【Linux】使用NetworkManager工具nmcli命令进行高级网络设置bond0-6
    NetworkManager工具nmcli(NetworkManager的命令行界面)命令行实用程序,用于控制NetworkManager和报告网络状态。它可以用作nm-applet或其他图形客户端的替代品。nmcli用于创建、显示、编辑、删除、激活和停用网络连接,以及控制和显示网络设备状态。对于服务器,虚拟机,终端,nmcli可以直......
  • Linux命令+VIM编辑
    ls命令ls:显示当前文件夹下的所有文件ls -l:长格式显示ls -a:显示隐藏文件 包括  . ..ls -A:显示隐藏文件 不包括 . ..ls -d:只显示当前目录的属性ls -R:递归显示所有ls  -t:以时间顺序显示ls -r:倒序显示(图中配合时间显示)du命......
  • Yarn命令全攻略:解锁前端开发的更多可能
    在前端开发的世界里,Yarn以其高效、稳定、可靠的特点,赢得了众多开发者的青睐。作为前端包管理工具,Yarn不仅提供了基础的依赖管理功能,还通过一系列丰富的命令,为我们解锁了前端开发的更多可能性。今天,就让我来为大家详细介绍一下Yarn的其他命令,带你领略它们的魅力所在。Yarn命......
  • 掌握ADB:详解操作命令及完整用法指南(二)
    前言ADB,全名AndroidDebugBridge,是Android提供的一个通用的调试工具,是一个C/S架构的命令行工具,通过这个工具,使得我们的PC能够和Android设备来进行通信。之前一篇文章我们介绍了adb安装以及一些adb的基础命令,本文我们将介绍一些我们在进行app自动化测试时经常使用到的命令。adb......