awk

时间:2024-10-13 21:26:26编辑:流行君

awk命令详解是怎么样的?

awk:用于一行中分成数个“字段”来处理。适合处理 小型数据。运行模式:awk '条件类型1{动作1} 条件类型2{动作2} ...' filename。# last | awk '{print $1 "\t" $3}' <== 查看登录者的数据,只显示登录名和ip地址,并以[tab]隔开awk 的内置变量。变量名称 代表的含义NF 每一行($0)拥有的字段总数NR 当前 awk 所处理的是 “第几行” 数据FS 当前分隔符,默认空格键awk 的逻辑运算符特点AWK是一种优良的文本处理工具。它不仅是 Linux 中也是任何环境中现有的功能最强大的数据处理引擎之一。这种编程及数据操作语言(其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母)的最大功能取决于一个人所拥有的知识。AWK 提供了极其强大的功能:可以进行样式装入、流控制、数学运算符、进程控制语句甚至于内置的变量和函数。

Linux入门系列——awk命令详解

awk是一个强大的文本分析工具,与grep、sed相比,awk在对数据分析并生成报告时,显得有很大的优势。 awk有三个不同的版本:awk、nawk和gawk,在没有做特殊说时的时候默认的就是gawk,gawk是awk的GNU版本。 其中command是真正的awk命令,-F表示域的分隔符,是个可选项。Filename是等待处理的文件 将所有的awk命令写入到一个文件,并使用该文件有X权限,然后awk命令解释器作为脚本的首行,也就是说可以把脚本最开始的 #!/bin/bash 换成 #!/bin/awk 最后直接执行这个脚本文件就行了。 -f 指定要加载的awk脚本,是一个文件。Filename是等待处理的文件 awk的工作流程是这样的:读入一行后(最后面带有” ”的),就按-F指定的分隔符来将该行划分成N个区域,$0表示所有的区域,$1表示第一个域,$2表示第二个域,依此类推,$n表示第n个域。 总结:awk先执行BEGIN内的命令,然后再读入文件中的行,接着就是按照指定的分隔符将该行分成N个区域,然后再来执行模式所对应的动作action。然后,再来读入第二行。。再重复执行action,直到所有的行都处理完成。最后再执行END中的命令。 注意:' // '之间是支持正则表达式的,如果此处只有pattern,而没有action,那么awk默认会把匹配到的行打印出来。 awk中的print还可以使用C语言中的printf来替代。在输出格式比较复杂的时候使用printf函数会比print函数要更直观一些,如下: 还可以使用-v key=value来自定义变量。如下: awk中的条件语句是从C中借鉴过来的 语法:if (condition) {then-body} else {else-body} 例如使用awk来统计某个目录下的普通文件的大小,不包括子目录的,并过滤掉目录。 循环语句也和C中的一样,支持while、do/while、for、continue、break等关键字。 break和continue常用于循环中; 在awk中,数组的下标可以是数字或字母。一般awk中的数组的作用是从记录中收集信息,用于计算总和、统计单词等。 在awk中要删除一个元素的时候使用 delete array[index] 更多请参见awk官方文档[http://www.gnu.org/software/gawk/manual/gawk.html]

上一篇:114电影

下一篇:没有了