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}'