linux 文件指定列长度,linux – unix – 文件中每列的max(长度)

给定一个包含这样数据的文件(即stores.dat文件)

sid|storeNo|latitude|longitude

2tt|1|-28.0372000t0|153.42921670

9|2t|-33tt.85t09t0000|15t1.03274200

期望的输出:

sid : 3

storeNo : 2

latitude : 16

longitude : 13

返回每列下值的最大长度的语法是什么?

我试过这个,但它不起作用:

nawk 'BEGIN { FS = "|" }

{

for(n = 1; n <= NF; n++) {

if (length($n) > max)

max = length($n)

maxlen[$n] = max

}

}

END {

for (i in maxlen) print "col " i ": " maxlen[i]

} ' stores.dat

更新(感谢Mat的回答 – 我已经解决了这个问题):

awk -F"|" ' NR==1{

for(n = 1; n <= NF; n++) {

colname[n]=$n

}

}

NR>1{

for(n = 1; n <= NF; n++) {

if (length($n)>maxlen[n])

maxlen[n]=length($n)

}

}

END {

for (i in colname) {

print colname[i], ":", maxlen[i]+0;

}

} ' filename

解决方法:

您的脚本存在一些问题 – 最大值在列之间共享,而您根本不处理标题行.请尝试以下方法:

$cat t.awk

#!/bin/awk -f

NR==1{

for(n = 1; n <= NF; n++) {

colname[n]=$n

}

}

NR>1{

for(n = 1; n <= NF; n++) {

if (length($n)>maxlen[n])

maxlen[n]=length($n)

}

}

END {

for (i in maxlen) {

print colname[i], ":", maxlen[i];

}

}

$awk -F'|' -f t.awk stores.dat

$n指第n列的内容. n是列号(在第一个和第二个循环中).最后一个循环只显示了一种在awk中迭代数组的方法.

标签:bash,shell,unix,linux,awk

来源: https://codeday.me/bug/20190530/1185067.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值