我从文件中提取具有不同值的列,其中一些是 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/' | ...