awk脚本

$0,意即所有域。

有两种方式保存shell提示符下awk脚本的输出。最简单的方式是使用输出重定向符号>文件名,下面的例子重定向输出到文件wow。
#awk ‘{print $0}‘ grade.txt > wow

第二种方法是使用tee命令,在输出到文件的同时输出到屏幕。
#awk ‘{print $0}‘ grade.txt | tee delete_me_and_die

打印field-1和field-4,
#awk ‘{print $1,$4}‘ grade.txt

打印信息头放置在BEGIN模式部分
#awk ‘BEGIN {print "Name        Belt\n----------------------"}{print $1"\t"$4}‘ grade.txt
END语句在所有文本处理动作执行完之后才被执行。
#awk ‘BEGIN {print "Name        Belt\n----------------------"}{print $1"\t"$4} END{"end-of-report"}‘ grade.txt

为使一域号匹配正则表达式,使用符号‘~’后紧跟正则表达式

如果只要打印brown腰带级别可知其所在域为field-4
可以写出表达式{if($4~/brown/) print $0}意即如果field-4包含brown,打印它。

匹配记录找到时,如果不特别声明,awk缺省打印整条记录。

if语句简写
#awk ‘$0 ~ /Brown/‘ grade.txt

匹配包含48的记录
#awk ‘$3~/48/ {print $0}‘ grade.txt

只匹配等于48,
#awk ‘$3=="48" {print $0}‘ grade.txt

不匹配符号是!~

小于
awk ‘{if($6 < $7) print $1}‘ grade.txt

设置大小写可使用[]符号
查询文件中级别为green的所有记录,不论其大小写,
awk ‘/[Gg]reen/‘ grade.txt

第一域的第四个字符是a,使用句点.
#awk ‘$1 ~ /^...a/‘ grade.txt

或关系匹配
#awk ‘$0 ~ /(Yellow|Brown)/‘ grade.txt

复合表达式即为模式间通过使用下述各表达式互相结合起来的表达式:
&& AND : 语句两边必须同时匹配为真。
|| OR:语句两边同时或其中一边匹配为真。
! 非求逆
#awk ‘{if($1=="P.bunny" && $4=="Yellow") print $0}‘ grade.txt
#awk ‘{if($1=="P.bunny" || $4=="Yellow") print $0}‘ grade.txt

awk内置变量
ARGC    命令行参数个数
ARGV    命令行参数排列
ENVIRON 支持队列中系统环境变量的使用
FILENAME        awk浏览的文件名
FNR     浏览文件的记录数
FS      设置输入域分隔符,等价于命令行-F选项
NF      浏览记录的域个数
NR      已读的记录数
OFS     输出域分隔
ORS     输出记录分隔符
RS      控制记录分隔符

快速查看记录个数,应使用NR
#awk ‘END {print NR}‘ grade.txt

使用NF变量显示每一条读记录中有多少个域,并在END部分打印输入文件名。
#awk ‘{print NF,NR,$0} END{print FILENAME}‘ grade.txt

检查文件中是否有记录。下面的例子只有在文件中至少有一个记录时才查询Brown级别记录。使用AND复合语句实现这一功能。
$awk ‘{if(NR>0 && $4~/Brown/) print $0}‘ grade.txt

NF的一个强大功能是将变量$PWD的返回值传入awk并显示其目录。这里需要指定域分隔符/。
#pwd
/usr/local/etc
#echo $PWD | awk -F/ ‘{print $NF}‘
etc

另一个例子是显示文件名
$echo "/usr/local/etc/rc.sybase" | awk -F/ ‘{print $NF}‘
rs.sybase
时间: 2024-12-19 14:49:30

awk脚本的相关文章

听说awk语言也可以编写脚本

导读 从 awk 系列开始,我们都是在命令行或者脚本文件里写一些简短的 awk 命令和程序.然而 awk 和 shell 一样也是一个解释型语言.通过从开始到现在的一系列的学习,你现在能写可以执行的 awk 脚本了. 概述 和写 shell 脚本差不多,awk 脚本以下面这一行开头: #! /path/to/awk/utility -f 例如在我的系统上,awk 工具安装在 /user/bin/awk 目录,所以我的 awk 脚本以如下内容作为开头: #! /usr/bin/awk -f 上面一

shell脚本(正则表达+sed+awk)

一. 正则表达式:   正则表达式(或称Regular Expression,简称RE)就是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式. 该模式描述在查找文字主体时待匹配的一个或多个字符串. 正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配.简单的说,正则表示式就是处理字符串的方法,它是以行为单位来进行字符串的处理行为, 正则表示式通过一些特殊符号的辅助,可以让使用者轻易的达到搜寻/删除/取代某特定字符串的处理程序.vim.grep.find.awk

一个电影的时间掌握Awk(Linux)文本处理脚本语言

可以查看我用CmdMarkDown写的在线版,会比下面看起来舒服:在线分享版 Awk Awk.sed与grep,俗称Linux下的三剑客,它们之前有很多相似点,但是同样也各有各的特色,相似的地方是它们都可以匹配文本,其中sed和awk还可以用于文本编辑,而grep则不具备这个功用.sed是一种非交互式且面向字符流的编辑器(a "non-interactive" stream-oriented editor),而awk则是一门模式匹配的编程语言,因为它的主要功能是用于匹配文本并处理,同时

awk数组、函数、脚本

一.awk关联数组 index-expression: (1) 可使用任意字符串:字符串要使用双引号括起来 (2) 如果某数组元素事先不存在,在引用时,awk会自动创建此元素,并将其值初始化为"空串" 若要判断数组中是否存在某元素,要使用"index in array"格式进行遍历 示例: weekdays["mon"]="Monday" awk 'BEGIN{weekdays["mon"]="M

shell脚本---grep、awk、sed工具

grep:Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来.grep是一种查找过滤工具,正则表达式在grep中用来查找符合模式的字符串. grep有三种变形: 1.grep:标准grep命令主要讨论此格式. 2.egrep:扩展grep,支持基本及扩展的正则表达式 3.fgrep:快速grep,允许查找字符串而不是一个模式.这里的快速并不是值速度快 格式 grep [options] 主要参数 [options]主要参数: -c:只输出匹配行

shell脚本知识(三) 正则表达式 grep sed awk

1.正则表达式 匹配给定文本中的所有单词:( ?[a-zA-Z]+ ?) ?用于匹配单词前后可能出现的空格. 匹配IP地址:[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}   括号分割的4个整数. 2.grep "mach_text"  file1 file2 file3-. 递归搜索文件: grep "text" ./ -Rn 3.cut  将文本按列进切分.可以指定分割每列的定界符.在cut术语中,每列一个字段. c

Linux文本处理三剑客之GNU awk的使用

awk: Aho, Weinberger, Kernighan,报告生成器,格式化文本输出 有多种版本:New awk(nawk),GNU awk(gawk) gawk –模式扫描和处理语言 基本用法: awk[options] 'program' var=value file- awk[options] -f programfile var=value file- awk[options] 'BEGIN{ action;... } pattern{ action;... } END{ acti

第4章 awk编程

1 awk编程模型       2 awk用法 调用awk有三种方法(与sed类似): 在Shell命令行输入命令调用awk,格式为: awk [-F 域分隔符] 'awk程序段' 输入文件 将awk程序段插入脚本文件后,然后通过awk命令调用它: awk -f awk脚本文件输入文件 将awk命令插入脚本文件后,最常用的方法是设置该脚本文件为可执行,然后直接执行该脚本文件,格式为: ./awk脚本文件输入文件 注:第二种方法脚本文件的首行不以#!/bin/awk –f开头:第三种方法脚本文件的

linux 下的 正则表达式(awk,sed,awk)学习

一.正则表达式: 正则表达式(或称Regular Expression,简称RE)就是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式. 该模式描述在查找文字主体时待匹配的一个或多个字符串. 正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配.简单的说,正则表示式就是处理字符串的方法,它是以行为单位来进行字符串的处理行为, 正则表示式通过一些特殊符号的辅助,可以让使用者轻易的达到搜寻/删除/取代某特定字符串的处理程序.vim.grep.find.awk.se