ask 是一种文本处理工具 ,一个强大的文本分析工具

格式: awk '/pattern/{command}' file1 file2 ... #行匹配语句awk' '只能用单引号

   -F          指定分隔符
		 -f           调用脚本
		 -v          定义变量
		 ' '           引用代码块
		 BEGIN  在对每一行进行处理之前,初始化代码
		 //           匹配代码块,可以是字符串或正则表达式
		 ;         多条命令使用分号分隔
		 END     对每一行进行处理之后再执行的代码块,主要是进行最终计算或输出                    结尾摘要信息
		 { }         包含一条或多条命令

特殊符号: $0 匹配整行 $1 每行的第一个字段 FS 输入域分隔符,默认为一个空格 RS 输入记录分隔符 NF 当前记录里域个数 NR 到目前为止记录数 OFS 输出域分隔符 ORS 输出记录分隔符 \t 制表符 \n 换行符 == 等于全部相等 != 不等于

例 awk '{print $0}' file 显示整行 awk '{print $1,$3}' file 显示匹配行的第一、三个域 awk '{print FNR,$0}' file file2 把两个文件合起来显示

	 统计/etc/fstab文件中每个文件系统类型出现的次数
	       awk '/^UUID/{fs[$3]++}END{for(i in fs){print i,fs[i]}}' /etc/fstab
	统计/etc/fstab文件中每个单词出现的次数
	     awk '{i=1;while(i<=NF){word[$i]++;i++}}END{for(num in word){print num,word[num]}}' /etc/fstab
	统计出/etc/passwd文件中shell的种类和个数
	     awk -F: '{shell[$NF]++}END{for (i in shell){print i ,

shell[i]}}' /etc/passwd