根据使用awk的其他行中的字符数在一行中添加零



我有一些文本文件,看起来像这样:

558903
5589157
55893434
55907235
.
.
.
127158709
1271587172
127158748

我只想更改每个文件的第一行和最后一行。

我想在第一行加上零,这取决于前10行中的字符数。例如,如果在前10行中,一行的最大字符数是8(就像我的例子一样),我需要在第一行中添加尽可能多的零,以便它也有8个字符(在本例中是两个零)

我的最后一行也需要同样的东西。因此,再次,我需要检查最后10行中的最大字符数(在我的示例中是10),并在最后一行添加尽可能多的零以拥有尽可能多的字符(在本例中只有一个零)。

我的输出应该是这样的:

55890300
5589157
55893434
55907235
.
.
.
127158709
1271587172
1271587480

在另一个帖子上有人帮助我使用这个脚本,但它根据所有行的最大字符数为所有行添加了尽可能多的零(我刚刚注意到,这不是我需要的,所以这是我的错,而不是他的)。

$ awk '
{
    max = ((max > length($1)) ? max : length($1))
    a[NR] = $1
}
END { 
    for(x=1; x<=NR; x++) {
        n = max - length(a[x])
        while(n-->0) {
            a[x] = a[x] "0"
        }
        print a[x]
    }
}' file

Try this:

awk '
NR==FNR {
    len[NR] = length($1)
    last = NR
    next
}
FNR==1 {
    for(i=1; i<=num; i++) {
        fm = ((fm>len[i])?fm:len[i])
    }
    for(j=(last); j>(last-num); j--) {
        lm = ((lm>len[j])?lm:len[j])
    }
    $1 = $1 * 10 ** (fm-length($1))
}
FNR==last {
    $1 = $1 * 10 ** (lm-length($1))
}1' num=10 file file

您可以将 num= 设置为您希望比较的任意行数。文件的第一行和最后一行将根据该范围内的最大长度由 0 追加。

使用sed,直接编辑您的文件:

head_max=$(( $(head -10 file.txt | wc -L) -1 ))
tail_max=$(( $(tail -10 file.txt | wc -L) -1 ))
sed -i.bk ":a 1 s/^.{1,$head_max}$/&0/;ta" file.txt
sed -i.bk ":a $ s/^.{1,$tail_max}$/&0/;ta" file.txt

相关内容

  • 没有找到相关文章

最新更新