awk是列操作命令
awk工作流程是这样的:读入有'\n'换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。默认域分隔符是"空白键" 或 "[tab]键",所以$1表示登录用户,$3表示登录用户ip,以此类推。
-F指定域分隔符为':'
last -n 5 | awk print '{$1}' 打印第一列的数据
last -n 5 | awk print '{$1,$2}' 打印第1,2列的数据
cat /etc/passwd | awk -F ':' '{print $1}'
cat /etc/passwd |awk -F ':' '{print $1"\t"$7}' tab键分割打印
awk工作流程是这样的:先执行BEGING,然后读取文件,读入有/n换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域,随后开始执行模式所对应的动作action。接着开始读入第二条记录······直到所有的记录都读完,最后执行END操作。
cat /etc/passwd | awk -F ':' 'BEGIN {print "hello,zhangyusheng"} {print $1"\t"$7} END {print "bye,zhangyusheng"}'
(注意begin,end外面有个单引号,awk语句一定要用单引号包住)
awk -F: '/root/' /etc/passwd 按照/xxx/中间的xxx作为pattern,用正则去搜索文件的行,有点像grep
搜索/etc/passwd有root关键字的所有行,并显示对应的shell
-----------------------------------------------------------------------------------------------------------------------------------------------------
example:
对一个文件 取中间部分 然后在 分割 (分割的元素利用substr 再次分割,然后元素拼接用\t拼接 方便导入excel)
sed -n "13,78p" ErrorHelper.php|awk -F" " '{print substr($4,0,5),"\t",substr($5,3)}'