我有一些文本文件,看起来像这样:
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