我有一个类似于他的文本文件:
#c1 c2 c3 c4 c5 c6 c7 c8 c9 c10 c11 c12 c13
4599 995,274 2523,658 264,1417170 -33,6000 -0,3600 0,0202 0,0069 0,0227 10,1041 0,0169 0,2817 0,0239
6173 1552,290 1595,696 264,0603912 -33,4880 0,4374 0,0287 1,8123 0,0385 10,1289 0,0292 2,8445 0,0366
6456 1658,630 1529,292 264,0449377 -33,4800 0,0109 0,0234 1,0955 0,0296 10,5032 0,0223 1,7168 0,0293
8932 2750,029 1374,395 263,8866195 -33,4615 -0,3185 0,0249 0,9196 0,0302 10,5858 0,0221 1,3886 0,0296
4095 820,716 495,315 264,1658451 -33,3546 -0,4388 0,0216 0,6497 0,0252 10,6026 0,0188 1,1796 0,0258
4737 1045,289 1395,983 264,1338240 -33,4636 0,5900 0,0231 0,8853 0,0273 10,6501 0,0204 1,1661 0,0270
即:未在某些随机行上对齐(文件长约 10000 行)我需要它看起来像这样:
#c1 c2 c3 c4 c5 c6 c7 c8 c9 c10 c11 c12 c13
4599 995,274 2523,658 264,1417170 -33,6000 -0,3600 0,0202 0,0069 0,0227 10,1041 0,0169 0,2817 0,0239
6173 1552,290 1595,696 264,0603912 -33,4880 0,4374 0,0287 1,8123 0,0385 10,1289 0,0292 2,8445 0,0366
6456 1658,630 1529,292 264,0449377 -33,4800 0,0109 0,0234 1,0955 0,0296 10,5032 0,0223 1,7168 0,0293
8932 2750,029 1374,395 263,8866195 -33,4615 -0,3185 0,0249 0,9196 0,0302 10,5858 0,0221 1,3886 0,0296
4095 820,716 495,315 264,1658451 -33,3546 -0,4388 0,0216 0,6497 0,0252 10,6026 0,0188 1,1796 0,0258
4737 1045,289 1395,983 264,1338240 -33,4636 0,5900 0,0231 0,8853 0,0273 10,6501 0,0204 1,1661 0,0270
所以基本上我正在寻找一个脚本/命令行实用程序来自动对齐文件的列。
答案1
尝试在壳:
测试STDOUT
:
column -t file.txt
修改文件:
column -t file.txt > new_file.txt && mv new_file.txt file.txt
如您所见,这就是您所需要的。它可以为您节省大量玩复杂printf
技巧的时间。
答案2
您正在寻找名称恰当的列工具。
对于你想要的,你必须将数据通过管道传输到这样的列
cat yourfile | column -s " " -t
使用 -s 定义分隔符
-s " "
告诉 colum 用 -t 来制作表格