废话不多说,直接上操作。
示例文本:
水果 苹果,橘子,香蕉,鸭梨
蔬菜 豆角,茄子,萝卜,白菜
手机 华为,酷派,联想,小米
0.awk完整结构(以计算某列总和为例)
echo -e "123\n234\n345\n456\n567\n678" | awk 'BEGIN{sum=0;printf "总和:"}{if(NR<=4)printf $1"+";sum+=$1; if(NR==6)printf $1 "="}END{print sum}'
1.通过空格分割种类与详细名称
awk -F ' ' '{print "种类:"$1,"包含:"$2}' file
通过-F命令,使用空格‘' '’对每一行数据进行分割
通过‘'{print "xxx"$n}'’ 进行拼接分割后的第n列数据,并打印
2.在1的基础上继续拆封详细子项
awk -F '[ ,]' '{print "种类:"$1,"包含:a="$2,"b="$3,"c="$4,"d="$5}' file
通过‘'[ ,]'’使每一行数据一次按空格、逗号进行分割数据
3.打印出行内包含橘子的数据
awk -F '[ ]' '$2~/橘子/{print $1,$2}' file
通过"$2~/橘子/"匹配到这一列内包含‘橘子’的每行数据,进行打印
4.打印出某列以华为开头的数据
awk -F '[ ]' '$2~/^华为/{print $1,$2}' file
5.根据空格分割后,打印第一列的长度
awk -F '[ ]' '{print length($1),$1}' file
修改示例文本:
fruit 苹果,橘子,香蕉,鸭梨
greenstuff 豆角,茄子,萝卜,白菜
phone 华为,酷派,联想,小米
6.打印种类名称长度为5的行数据
awk -F '[ ]' 'length($1)==5{print length($1),$1,$2}' file
7.打印符合6题的数据行数及文件内数据总行数
awk -F '[ ]' 'length($1)==5{i++;print length($1),$1,$2}END{print i,NR}' file
8.NF、NR、FNR简单说明
8.1 打印第1列,第12行数据
awk 'NF=1&&NR==12' executor-application.log
8.2 含义
NF:表示列
1NF:表示第一列
$NF:表示最后一列
9.排序问题
可以使用系统sort sort -r 进行正序倒序排列
10.结果去重
awk '!(1];print $1}'
持续更新中...