ファイルの差分を見る!diffコマンドの詳細まとめ【Linuxコマンド集】

diff
  • このエントリーをはてなブックマークに追加
  • Pocket

diffはファイル同士の差分を表示するLinuxコマンドだ。

プログラムの更新時にどこを変更したかをリストするなど多くのシチュエーションで活躍する便利なコマンドだ。Linuxを扱うエンジニアであれば、使う機会が頻繁にあるだろう。

詳細を含めてdiffコマンドについてまとめてみた。コマンド実行例についてもすべてまとめているので、参考になるだろう。

コマンドの基本

コマンドの基本動作

使い方は、次のとおりコマンドの後に比較するファイル2つのファイルを指定するだけだ。

$ diff 比較するファイル1 比較するファイル2

例えば、workディレクトリ内の2つのファイル、test1.datとtest2.datの差異を表示する場合は、次のようになる。

$ diff work/test1.dat work/test2.dat

01:diff-1

test1.datに対するtest2.datの差異が表示された。

結果に2c2と表示されているが、比較するファイル1の2行目が比較するファイル2の2行目に変更(c:Change)されているという意味だ。

その下に、差異のあった比較するファイル1の2行目の内容

---を挟んで、比較するファイル2の2行目の内容

が表示されている

上記diffコマンドを試すなら下のコマンドをLinux上で実行すればすぐに再現可能だ。

差異が複数行の場合

差異が複数行の場合は、どのような表示なるか確認してみよう。

比較するファイル2の2行目と3行目の内容を書き換える。

$ echo -e "ab\nc1\nd1" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

02:diff-2

結果に2,3c2,3と表示されているが、比較するファイル1の2行目と3行目が比較するファイル2の2行目と3行目に変更(c:Change)されているという意味になる。

差異が離れた複数行の場合

差異が離れた複数行の場合は、どのような表示なるか確認してみよう。

比較するファイル2の1行目と3行目の内容を書き換える。

$ echo -e "ab1\nc\nd1" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

03:diff-3

結果が1c1と3c3の2つが表示された。比較するファイル1と比較するファイル2では、1行目同士、3行目同士が変更(c:Change)されているという意味だ。

削除された場合

行が削除された場合は、どのような表示なるか確認してみる。比較するファイル2を2行目がないものと置き換える。

$ echo -e "ab\nd" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

04:diff-4

結果が2d1と表示された。比較するファイル2では、比較するファイル1の2行目が削除(d:Delete)され、以降のテキストが1行の直後まで詰まったという意味だ。

追加された場合

行が追加された場合は、どのような表示なるか確認してみよう。

比較するファイル2を3行目が追加されたものと置き換える。

$ echo -e "ab\nc\ne\nd" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

05:diff-5

結果が2a3と表示された。比較するファイル2では、比較するファイル1の2行目の直後に3行目が追加(a:Append)されているという意味だ。

入れ替わっている場合

行が入れ替わった場合は、どのような表示なるか確認してみよう。比較するファイル2の2行目と3行目を入れ替えたものと置き換える。

$ echo -e "ab\nd\nc" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

06:diff-6

結果が2d1と3a3の2つが表示された。入れ替わりは、削除と追加で表現される。

変更がない場合

内容が同一で変更のない場合は、どのような表示なるか念のため、確認しておく。

比較するファイル2を比較するファイル1の内容と同一にする。

$ echo -e "ab\nc\nd" > work/test2.dat

先ほどのdiffコマンドで同様に比較してみる。

$ diff work/test1.dat work/test2.dat

07:diff-7

変更がない場合、結果はなにも表示しない。

diffコマンドの便利なオプションたち

コマンドの一覧

後から詳細をご紹介するが、まずは一覧で確認しておく。

オプション -s

ファイルが異なるかのみチェックする

オプション -q

ファイルが異なるかのみチェックし同一の場合は結果を出力しない

オプション -c

結果をコンテキスト形式で表示する

オプション -C

差異のあった行から指定した行数をコンテキスト形式で表示する

オプション -u

結果をユニファイド形式で表示する

オプション -y

比較した結果を横並びで表示する

オプション -r

ディレクトリ同士で比較する

-sオプション:ファイルが異なるかのみチェックする

どこに差異があるかではなく、単純にファイルが同一のものかどうかを表示するオプションだ。

$ diff –s 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの差異を同一かどうかのみ表示する場合は、次のコマンドになる。

$ diff –s work/test1.dat work/test2.dat

diff -s

同一なので、同一と表示された。

-sオプションの差異があった場合の表示を確認しよう。比較するファイル2の2行目の内容を書き換える。

$ echo -e "ab\nc1\nd" > work/test2.dat

もう一度、先ほどと同様の-sオプションのコマンドで確認してみよう。

$ diff –s work/test1.dat work/test2.dat

diff -s

異なる部分が差異として表示された。

-qオプション:ファイルが異なるかのみチェックし同一の場合は結果を出力しない

-sオプションと同様、どこに差異があるかではなく、単純にファイルが同一のものかどうかを表示する。しかし、-qオプションは結果が同じ場合はなにも出力しないオプションだ。

$ diff –q 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの差異を同一かどうかのみ表示する場合は、次のコマンドになる。

$ diff –q work/test1.dat work/test2.dat

diff -q

異なると表示された。

-qオプションの差異がなかった場合の表示を確認しよう。

比較するファイル2を比較するファイル1の内容と同一にする。

$ echo -e "ab\nc\nd" > work/test2.dat

もう一度、先ほどと同様の-qオプションのコマンドで確認してみる。

$ diff –q work/test1.dat work/test2.dat

diff -q

同一の場合はなにも表示しない。

-cオプション:結果をコンテキスト形式で表示する

結果をコンテキスト形式で表示するオプションだ。結果が同一の場合はなにも表示しない。

$ diff –c 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの差異をコンテキスト形式で表示する場合は、次のコマンドだ。

$ diff –c work/test1.dat work/test2.dat

10:diff-10

異なる部分がコンテキスト形式で表示された。

コンテキスト形式では、比較するファイル1と比較するファイル2のファイル名とタイムスタンプが表示され、差異のある行は変更された行から前後に数行表示される。差異のある行は「!」でわかるようになっている。

上記のオプションは次のコマンド一群でトライできる。

-Cオプション:結果をコンテキスト形式で表示する

-cオプション同様、結果をコンテキスト形式で表示するオプションだが、表示する行数を指定できる。結果が同一の場合はなにも表示しない。

$ diff –C 行数 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの差異をコンテキスト形式で表示、差異のあった前後に2行表示する場合は、次のコマンドだ。

$ diff –C 2 work/test1.dat work/test2.dat

diff

異なる部分が前後2行と共にコンテキスト形式で表示された。

diff -C 2 work/test1.dat work/test2.dat

-uオプション:結果をユニファイド形式で表示する

結果をユニファイド形式で表示するオプションだ。結果が同一の場合はなにも表示しない。

$ diff –u 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの差異をユニファイド形式で表示する場合は、次のコマンドだ。

$ diff –u work/test1.dat work/test2.dat

diff

異なる部分がユニファイド形式で表示された。

ユニファイド形式では、比較するファイル1と比較するファイル2のファイル名とタイムスタンプが表示され、変更という表現ではなく、差異のある行は追加が+、削除が-でわかるようになっている。

-yオプション:比較した結果を横並びで表示する

比較した結果を横並びで表示するオプションだ。結果が同一でも表示する。

$ diff –y 比較するファイル1 比較するファイル2

workディレクトリ内の2つのファイル、test1.datとtest2.datの比較結果を横並びで表示する場合は、次のコマンドだ。

$ diff –y work/test1.dat work/test2.dat

diff

比較した結果が横並びで表示された。差異のある行は|でわかるようになっている。

diff -y work/test1.dat work/test2.dat

-rオプション:ディレクトリ同士で比較する

ディレクトリ同士で比較するオプションだ。

$ diff –r 比較するディレクトリ1 比較するディレクトリ2

workディレクトリ内のdata1ディレクトリとdata2ディレクトリの2つのディレクトリ内のファイル同士を順次比較する場合は、次のようになる。

$ diff –r work/data1/ work/data2/

diff -r

比較の結果がオプションなしと同じ形式で表示される。片方にしか存在しないファイルは、片方にのみ存在と表示される。

上記のオプションは次のコマンドで演習できる。

複数のオプションを組み合わせる

複数のオプションを組み合わせると、視認性が飛躍的に向上する。

例えばworkディレクトリ内のdata1ディレクトリとdata2ディレクトリの2つのディレクトリ内のファイル同士を横並びで比較する場合は、次のようにする。

$ diff –ry work/data1/ work/data2/

diff -ry

ファイルごとに順次結果が横並びで表示される。

apple.datの差異のある部分に|が表示され、grape.datは差異がなかった。orange.datはdata1ディレクトリにしか存在しなかったという結果が、とてもわかりやすく表現された。

ちなみに-yオプションで-cや-uでの形式の変更オプションは同時には使えない。

関連項目

最後にdiffコマンドに関連して、基本的なファイル検索のコマンドも紹介しておく

find

ファイル名やディレクトリ名、更新日付などで検索する。

grep

ファイル内の文字を検索する。

echo

また、本文中でechoコマンドを使っているが、こちらのページを参考にして欲しい。

まとめ

diffコマンドを使ったファイルやディレクトリの比較の方法を解説してきた。

プログラミング中に自分で変更した点がわからなくなったとき、あらかじめバックアップしておいたファイルと比較することで、変更点を簡単に把握できる。

自分が作成したファイルを他人に改変してもらって、どこを変えてきたか、いちいち報告を受けなくてもこのコマンドを使えはすぐにわかる。

また、差分の結果をターミナルの画面上でコピーする操作やファイルへリダイレクトすることで変更履歴のドキュメントをすぐに作成でき、また、コンテキスト形式で保存しておけば外部の履歴管理ソフトなどでのバージョン管理の手続きもかなり効率化できる。

プログラマだけではなくHTMLおよびCSSのコーダーやデータベース管理者にとっても応用の範囲はかなり広いので、ぜひこの機会に操作方法を把握して欲しい。

  • このエントリーをはてなブックマークに追加
  • Pocket

このページの続きや関連ページは下記から一覧で確認できます。

IT講師に興味はありませんか?

・「今までIT講師をやってきたが、更に多くの講義を行いたい」

・「エンジニアとしてやってきたが講師業に魅力を感じている」

・「講師として活躍するためにベースとなる知識を知りたい」

・「様々な分野や言語の講師にチャレンジしてみたい」


という方はぜひIT講師募集のページをご覧ください。


リスキルテクノロジーでは「受講している方々にITを好きになってもらう」ことを目標に、同じ目標に向かって歩んで行ける講師の方を常に探しています。


システム開発やインフラ構築などのエンジニアリング経験を活かし、新入社員などの未経験者や経験の浅い初学者の方々に対してITトレーニングを行っていただくことになります。


テキストやカリキュラムは事前に用意されており、それらを元に講義を進めていくため、IT講師をはじめて実施する方でも安心してトレーニングを実施できます。


IT講師募集のページを見る

SNSでもご購読できます。

コメント

コメントを残す

*

未経験からの育成制度も充実
IT講師に興味はありませんか?

リスキルテクノロジーでIT講師の積極募集を開始! 経験・未経験問わずご応募可能。育成制度で講師スキル向上も目指せます

IT講師に応募する