Awk随记

来自三线的随记

awk、grep、sed是linux操作文本的三大利器,合称文本三剑客

awk内置字符串函数

gsub(r,s)    在整个$0中用s替代r
gsub(r,s,t)    在整个t中用s替代r
index(s,t)    返回s中字符串t的第一位置
length(s)    返回s长度
match(s,r)    测试s是否包含匹配r的字符串
split(s,a,fs)    在fs上将s分成序列a
sprint(fmt,exp)    返回经fmt格式化后的exp
sub(r,s)    用$0中最左边最长的子串代替s
substr(s,p)    返回字符串s中从p开始的后缀部分
substr(s,p,n)    返回字符串s中从p开始长度为n的后缀部分 详细说明一下各个函数的使用方法。


awk和Ta的常见变量们

NR 当前处理行数
FNR 在awk处理多个输入文件的时候,在处理完第一个文件后,NR并不会从1开始,而是继续累加,因此就出现了FNR,每当处理一个新文件的时候,FNR就从1开始计数
NF 当前处理行总字段数

分隔符

FS:Field Separator,字段分隔符

OFS:Out of Field Separator,输出字段分隔符

Example

awk排除第一行然后输出

awk '{if(NR>1)print $0}'

对于多个docker images用一行命令retag然后push到指定registry下的指定namespace

docker images| awk '/string/{gsub("origin_registry/origin_ns","registry/ns",$0);printf "docker tag "$3" "$1":"$2";docker push "$1":"$2"\n"}'|sh

将string替换成需要筛选过滤的image (可选)

按需修改"origin_registry/origin_ns" 和 "registry/ns"参数为实际需要执行即可

执行前可以将最后的 |sh 去掉以debug命令

在awk中同时重定向输出

echo string1234 | awk '{print " contents "$0 >> "demo"}'

在awk中格式化输出

echo  1 2 3 4 5| awk '{printf "%-30s %-30s %-5s %-5s %s\n",$1,$2,$3,$4,$5}'