当值为 12 个字符时添加 0

当值为 12 个字符时添加 0

我从文件中提取具有不同值的列,其中一些是 11 到 13 个字符,但每当值为 11 时,我需要在前面添加 0。

awk -F, '{print $1 }' $FILE | \
 awk '{printf("%04d%s\n", NR, $0)}' | \
 awk '{printf("%-12s\n", $0) }'

82544990078
82544990757
899188001738
9337402002723
9337402002686
9337402002747
812153010733
852271005003
89000118359

它应该看起来像这样:

082544990078
082544990757
899188001738
9337402002723
9337402002686
9337402002747
812153010733
852271005003
089000118359

答案1

您可以awk为此使用:

$ awk 'length() == 11 { $0 = "0" $0 } 1' < input
082544990078
082544990757
899188001738
9337402002723
9337402002686
9337402002747
812153010733
852271005003
089000118359

答案2

... | sed 's/^(.\{11,11\})$/0\1/' | ...

相关内容