标签:语言 express 行编辑器 if while efault 不用 注意 nbsp ==
${test}、${#test}、${test:offset:length}、${test#*word}、${test##*word}、${test%word}、${test%%*word}、${test/pattern/string}、${test//pattern/string}、${test:-word}
awk 报告生成器
通过模式匹配以及自己本身的语言格式,来获取、并输出客户所需要的内容;for i in $(cut -d: -f3 /etc/passwd);do if [ $i -ge 1 -a $i -le 500 ];then echo grep $i | cut -d: -f1,3 fi done
awk -F: ‘{if($3>=1&&$3<=500){print $3}}‘ /etc/passwd
awk -F: -v OFS=":" ‘BEGIN{printf " username uid \n========================\n"}{if($3>=1&&$3<=500){printf "用户名:%-10s UID:%-10d\n",$1,$3}}END{printf "---------------------------\nend\n"}‘ /etc/passwd
awk [option] ... ‘program‘ FILE ...
1、program 必须使用 !单引号!
2、多条program语句使用大括号包含起来,可以并列,可以嵌套awk ‘{print}‘ /etc/passwd
awk -F[/:] ‘{print $1,$3}‘ a.txt
其中 [ ] 内表示多个字符中的任意一个
-v 因为awk是一种语言编译器,能自己定义变量,同时也有内置变量(与环境变量类似)awk -v a="a/b" ‘{print a}‘ a.txt
给a赋值,打印a这个变量
1、a是自定义变量 -v FS=":"awk ‘{a="a/b";print a}‘ a.txt
扩展:了解 cut 与 awk 的区别;
awk ‘{a="a/b";print a}‘ a.txt | tee a.bak
2、printf -- 实现格式化输出
printf "%s是%d班学的最好的学生",变量1,变量2
格式符 %s 字符串 %d %i 数值 %e %E 科学计算数值 %c ACSii码值 %f 浮点数 %u 无符号整数 %% 逃逸符 只显示 % 自己 修饰符 默认为右对齐 - 代表左对齐 %5.4f 5 所占位数 4 所取小数位
awk ‘/^UUID/{printf "被挂载文件:%-50s 挂载点:%-10s 文件系统格式:%-10s\n",$1,$2,$3}‘ /etc/fstab
注意:这里提到了地址定界
sed /PAT1/,/PAT2/awk -v FS=":" ‘/\/bash$/{print $1,$NF}‘ /etc/passwd
NR 定义文件的行数,定义多个文件的文件的,行号叠加
FNR 文件只计算自己的行号awk ‘{print NR}‘ /etc/fstab /etc/passwd awk ‘{print FNR}‘ /etc/fstab /etc/passwd
FILENAME 存储文件的名字
awk ‘{print FILENAME}‘ /etc/passwd //把文件名打印N次,N文件的行数 awk ‘BEGIN{print FILENAME}‘ /etc/passwd //BEGIN{语句} 只在行循环开始时,执行一次;
ARGC 整个命令的 段数 【注意:不包含 ‘program‘ 本身】
ARGV 数组,用来调取命令中,指定的段 ARGV[2] 【注意:数组中也不包含 ‘program‘ 】awk ‘BEGIN{print ARGC}‘ /etc/passwd /etc/fstab /etc/shadow awk ‘BEGIN{print ARGV[3]}‘ /etc/passwd /etc/fstab /etc/shadow
RS 指定换行符 \n 可以指定新的换行符,不影响本身的换行
ORS 输出的时候指定的换行符,将默认换行符替换为指定字符awk -v RS=" " ‘{print}‘ /etc/passwd awk -v ORS=" " ‘{print}‘ /etc/passwd //可以用来取消换行
自定义变量
-v 变量=值awk -v a="a/b" ‘{print a}‘ a.txt awk ‘{a="a/b";print a}‘ a.txt
4、模式匹配(地址定界)
sed -n ‘1,3p‘ /etc/passwd awk ‘1,3{print}‘ /etc/passwd //awk默认不支持使用 1-3 1,3 等等,这样数值的直接写法; awk ‘NR>=1&&NR<=3{print}‘ /etc/passwd //通过NR变量来指定
3、/pat1/
sed -n /pat1/p /etc/passwd awk ‘/r..ter/{print}‘ /etc/passwd
4、/pat1/,/pat2/ 第一次匹配pat1到第一次匹配pat2,之间的行
练习:判断/^r..ter/,/^user.*\>/之间的行的用户,是bash的用户,并显示用户的用户名,和UID======================================== ?shell: for i in `awk ‘/^r..ter/,/^user.*\>/{print $NF}‘ /etc/passwd`;do if [[ $i == "/bin/bash" ]];then echo `` fi done while line;do if [[ "/bin/bash" == `awk -F: ‘{print $NF}‘ $line` ]];then awk -F ‘{print $1,$3}‘ $line fi done << `sed -n ‘/^r..ter/,/^user.*\>/p‘ /etc/passwd` ========================================
awk -F: ‘/^r..ter/,/^user.*\>/{if($NF==/bin/bash);print $1,$3}‘ /etc/passwd
5、模式匹配可以直接使用判断语句
awk -F: ‘$NF=="/bin/bash"{print $1,$3}‘ /etc/passwd
6、BIGEIN|END语句
BIGEIN定义在默认循环进行操作前所要执行的语句;awk -F: ‘BEGIN{printf "shell程序为bash的用户为:\n"}$NF=="/bin/bash"{print $1,$3}‘ /etc/passwd awk -F: ‘BEGIN{printf "shell程序为bash的用户为:\n"}$NF=="/bin/bash"{print $1,$3}END{printf "end\n"}‘ /etc/passwd
一般在格式化输出的时候,打印表头和表未;
awk -F: ‘$NF~"/bin/bash"{print $1,$3}‘ /etc/passwd awk -F: ‘$NF!~"/bin/bash"{print $1,$3}‘ /etc/passwd
awk ‘/^title/{FN<=2? print: printf "参数过\n"}‘ /boot/grub/grub.conf //有点问题
6、常见action
awk ‘/^title/{FN<=2? print: printf "参数过\n"}‘ /boot/grub/grub.conf //有点问题
2、while语句
只有对行参数进行遍历的时候才会使用循环;初始值 while 条件判断;do 循环体 初始控制语句 done awk ‘/^[[:space:]]*kernel\>/{i=1;while(i<=NF){printf $i"\t";print length($i);i++}}‘ grub.conf
3、for语句
语法格式:for(初始值;条件判断;初始值控制语句){循环体}awk ‘/^[[:space:]]*kernel\>/{for(i=1; i<=NF; i++){printf $i"\t"; print length($i)}}‘ grub.conf
循环建议使用for语句
for i in 列表;do 循环体 done for(i in 列表){循环体} echo "xia liang z shi k hen n shuai da fa le " | awk ‘{for(i in {1..NF}) { ls=() if(length(ls[i])<=3){print $i}}}‘ shell
=====================================
ls=(xia liang z shi k hen n shuai da fa le) for i in `seq 0..${$ls[*]}`;do if [[ ${#${ls[$i]}} <= 3 ]];then print ls[$i] fi done
=====================================
awk ‘{if(NR%2==1) {next} else {print}}‘ /etc/passwd
6、switch 类似于case
switch(expression){case VALUE1 or /REGXP/: statement; case VALUE2 or /REGEXP2/:statement; … ,default: statement} switch(表达式){case 模式匹配值:执行语句;case 模式匹配值:执行语句,...,default:执行语句} 文件
shell:
case 变量 in pat1) 执行语句 ;; *) 执行语句 ;; esac
*8、数组*
awk -v RS=" " {print} a.txt | awk ‘{ls[$1]++}END{for(i in ls){print i,ls[i]}}‘
练习:统计一下一个文件中每个单词(以空格隔开的字符串)出现的次数;
awk ‘{for(i=1;i<=NF;i++){count[$i]++}}END{for(i in count) {print i,count[i]}}‘ /etc/fstab awk ‘{for(i=1;i<=NF;i++){ls[$i]++}}END{for(j in ls){print j,ls[j]}}‘ /var/log/httpd/access_log | sort -t" " -k2 -nr
9、函数
awk ‘{print sub(o,O,$1)}‘ /etc/fstab //将o 替换为 O 文件中的 第一列(第一个匹配值)
gsub(x,x,x) 替换该行所匹配到的所有值
awk ‘{print gsub(o,O,$1)}‘ /etc/fstab //将 o 替换为 O 文件中的 第一列(全部匹配值)
split(x,x,x) 指定分隔符去切割文件
netstat -tan | awk ‘/^tcp\>/{split($5,ip,":");print ip[1]}‘ netstat -tan | awk ‘/^tcp\>/{split($5,ip,":");count[ip[1]]++}END{for (i in count) {print i,count[i]}}‘
2、自定义函数
标签:语言 express 行编辑器 if while efault 不用 注意 nbsp ==
原文地址:https://www.cnblogs.com/lzqitdl/p/11396851.html