sedとは、POSIX環境のために作られたコマンドラインエディタです。sedは編集スクリプトの指示のもとに複数のファイルを編集し、標準出力にその結果を出力します。
UNIXとは、AT&Tのベル研究所で開発されたコンピューター用のマルチユーザー・マルチタスクのオペレーションシステム(OS)です。政府や教育機関や研究所で広範囲に採用されています。
AWKは、UNIX 上で開発されたプログラミング言語で、CSVファイルなどのテキストファイルの処理を目的にデザインされています。
Q&A
解決済
1回答
3935閲覧
総合スコア14
0グッド
0クリップ
投稿2015/01/19 17:59
0
sort -uとuniqコマンドでは削除できるんですが、sedとかawkではできないでしょうか?
回答お待ちしています。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
質問へのコメント
回答1件
ベストアンサー
awk '!x[$0]++' file.txt
このコマンドを使ってください。
xは連想配列で、Awkがそこにファイルの行すべてをパスします。 ある行が配列に存在しなければ、x[$0]がfalseと評価します。 !はロジカルなNOT演算子で、falseをtrueに逆転させます。 Awkはその式がtrueと評価した行をプリントします。 ++はxをインクリメントし、行が見つからなければx[$0] == 1、また見つからなければx[$0] == 2となっていきます。
また、0と" "(空のstring)だけはtrueと評価されません。 重複した行がxにある場合、!x[$0]がfalseと評価するためアウトプットには書かれません。
投稿2015/01/20 03:52
総合スコア93
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
15分調べてもわからないことはteratailで質問しよう!
ただいまの回答率85.48%
質問をまとめることで思考を整理して素早く解決
テンプレート機能で簡単に質問をまとめる
Unixのファイルで重複した行を削除したい(sed)
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。