非常に単純な問題がありますが、何らかの理由で動作しません。
.txt
このファイルは次の形式です。
2 250 1
4 250 1
5 250 1
最初の列の数字から1を引いて、次のようにしたいと思います。
1 250 1
3 250 1
4 250 1
私はbashでこのコードを使います:
awk '{ print $1-1,$2,$3 }' file.txt > newfile.txt
私はこのコードが大丈夫だと思いましたが、このテキストファイルのファイル拡張子がから変更されたため、.csv
この.txt
awk行は正しく機能しないようです。それは次のものを生成します:
1 250 1
4
私が持っているテキストファイルとうまく機能する代替手段がありますか?
更新:picoエディタを使用してファイルの1つを再生成しましたが、上記のコードは完全に実行されるため、フォーマットとプロパティの面で元のテキストファイルに問題があるようです...どのような洞察がありますか?
答え1
説明されている問題は行末に関連しているようです。テキストファイルにキャリッジリターン/改行文字がある場合、awk
キャリッジリターンは別の空白文字として扱われ、出力からテキストを上書きします。
編集によるOP pico
(これに伴い改行行末を想定)改行文字を設定する簡単な方法ページ)。dos2unix
Fix Line Endingsなどのプログラムを使用することもできます。
追加資料:
答え2
@Thomas Dickeyが言ったのが解決策のようです!
このコードを使用して、perl -pe 's/\r\n|\n|\r/\n/g'
テキストファイルをUnix形式に変換します。 dos2unixプログラムに似ています。今Awkは完璧に動作します!
みんなありがとう
答え3
このunix2dos/dos2unix
ユーティリティを使用すると、この問題を簡単に解決できます。マシンがある場合は、UNIX/Linux
マシンをインストールして次のコマンドを実行してみてください。
dos2unix file
テキストファイルを処理する前にユーティリティを実行して、そのファイルのエンディアンが何であるかを判断するのはUNIX/Linux
妥当です。file