Categories: TutorialsUbuntu

diff Command in Linux

Introduction

diff is an acronym for the difference. It is a useful command used to compare the differences between files based on the lines of the file.

This command just tells us which line to change in the file to make the 2 files the same. To be more precise, it creates a list of changes in the first file to match the second file.

This tutorial will guide you on how to compare two text files by the diff command in Linux as you go through below.

The syntax of diff command

$ diff [options] file1 file2

You need to remember some special symbols of diff:

Sponsored

a: add

c: change

d: delete

For example, I have 2 files a.txt and b.txt

Now we will try to use the diff command with these 2 files:

$ diff a.txt b.txt

Output:

This command will print out:

  • Corresponding line number.
  • Special symbols.

Definition:

0a1,2 means from line 0 you need to add Malaysia and Campuchia to lines 1, 2 of the first file.

3,5c5 means from line 3 to line 5 of the first file you need to change it to match line 5 of the second file.

— to separate line 1 from line 2.

Options

1. -c (context): Provides context to easily spot the differences

We will apply with files a.txt and b.txt:

$ diff -c a.txt b.txt

Output:

*** to specify the first file

Sponsored

— to specify the second file

+ to specify lines that need to add to the first file

! to specify lines that changed

2. -u (unified): To check differences in unified mode

$ diff -u a.txt b.txt

Output:

— to specify the first file

+++ to specify the second file

@@ mark the beginning of changes and which line of each file

3. -i: To case sensitive

For example, I have 2 files a.txt and b.txt

Now we will try to use the diff command with -i option with these 2 files:

$ diff -i a.txt b.txt

Output:

4. –version: Check your version

$ diff --version

Output:

Conclusion

In this article, we guided you on how to compare two text files by the diff command in Linux.

Thanks for reading!

Ubuntu Server Admin

Recent Posts

How is Livepatch safeguarded against bad actors?

Canonical Livepatch is a security patching automation tool which supports reboot-less security updates for the…

4 hours ago

Accelerating data science with Apache Spark and GPUs

Apache Spark has always been very well known for distributing computation among multiple nodes using…

4 hours ago

Cut data center energy costs with bare metal automation

Data centers are popping up everywhere. With the rapid growth of AI, cloud services, streaming…

1 day ago

Build the future of *craft: announcing Starcraft Bounties!

Our commitment to building a thriving open source community is stronger than ever. We believe…

1 day ago

NodeJS 18 LTS EOL extended from April 2025 to May 2032 on Ubuntu

The clock was ticking: Node.js 18’s upstream End of Life (EOL) The OpenJS Foundation is…

1 day ago

Native integration now available for Pure Storage and Canonical LXD

June 25th, 2025 – Canonical, the company behind Ubuntu, and Pure Storage, the IT pioneer…

2 days ago