Get the unique lines of second file in result of comparing two files

I have two text files, and I want to read file1 line by line, searching for the same line in file2 and removing it from file2.

I have the pseudocode of:

for line in file1.txt
do
  sed search line and delete in file2.txt
done

Solution 1:

You could accomplish this with grep.

Here is an example:

$ echo localhost > local_hosts

$ grep -v -f local_hosts /etc/hosts
127.0.1.1       ubuntu

# The following lines are desirable for IPv6 capable hosts
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters

Solution 2:

Generally you want to keep the lines in file2 that are not in file1 actually.

There are more possibilities of these,

comm <(sort file1) <(sort file2) -23

via join

join -v 1 <(sort file1) <(sort file2)

or via AWK which doesn't need to sort the files:

awk 'NR==FNR{lines[$0];next} !($0 in lines)' file2 file1