awk将文本转置(行转列)-以及if判断

创建文件abc

1,2,3,4
a,b,c,d

执行:

awk -F, '{for(i=1;i<=NF;i=i+1){a[NR,i]=$i}}END{for(j=1;j<=NF;j++){str=a[1,j];for(i=2;i<=NR;i++){str=str " " a[i,j]}print str}}' abc

结果:

1 a
2 b
3 c
4 d

等效命令1:

awk -F, '{for(i=1;i<=NF;i++){if(NR == 1){a[i]=$i;}else{a[i]=a[i]" "$i;}}}END {for(i=1;a[i]!="";i++){print a[i];}}' abc

等效命令2:

awk -F, -f ak.awk  abc

需先创建ak.wak脚本

#!/bin/awk -f
{
    for(i=1;i<=NF;i++){
        if(NR == 1){
            a[i]=$i;
        }else{
            a[i]=a[i]" "$i;
        }
    }
}
END {
    for(i=1;a[i]!="";i++){
        print a[i];
    }
}

输出文本中大于10的行

文件内容:

a 1
b 2
c 5
d 10
f 22
g 12
h 15
i 3
k 2

输入大于10的行

cat abc |awk  '{if ($2>10) print $1}'
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值