ASCIIファイルの列を揃える


12

彼のようなテキストファイルがあります。

#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

したがって、基本的には、ファイルの列を自動的に調整するスクリプト/コマンドラインユーティリティを探しています。

回答:


12

これをで試してください:

テストするにはSTDOUT

column -t file.txt

ファイルを変更するには:

column -t file.txt > new_file.txt && mv new_file.txt file.txt

ご覧のとおり、必要なのはそれだけです。複雑なprintfトリックで遊ぶ時間を大幅に節約できます。


このコマンドは何もせず、単にファイルを端末に表示して終了しました。ここで何が欠けていますか?
ガブリエル

どのOSを使用していますか?(元のPOSTに入れてください)
ジルケノー

Ubuntu 12.10を使用しています。
ガブリエル

もう一度試してみましたが、何もありません。そのコマンドは、元のファイルを変更するか、新しい整列されたファイルを作成する必要がありますか?
ガブリエル

ファイルを
インプレースで

3

適切な名前の列ツールを探しています。

あなたが望むもののために、あなたはこのように列にデータをパイプする必要があります

cat yourfile | column -s " " -t

-sで区切り文字を定義します

-s " "

-tを使用してcolumeにテーブルを作成するように指示します


これは"some data\nfoo bar"どういう意味ですか?
ガブリエル

それはOPが尋ねたものではありません;)
ジルケノー

@sputnick、私はそれを修正しました。ごめんなさい
-Silverrocker
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.