Unter der Annahme, have Dateien a.txt und b.txt mit
cat a.txt
a
b
c
d
1
3
5
cat b.txt
a
1
2
6
7
Denken Sie daran, NR und FNR sind awk eingebaute Variablen. NR - Gibt die Gesamtzahl der verarbeiteten Datensätze an. (in diesem Fall sowohl in a.txt als auch in b.txt) FNR - Gibt die Gesamtanzahl der Datensätze für jede Eingabedatei (Datensätze in entweder a.txt oder b.txt)
awk 'NR==FNR{a[$0];}{if($0 in a)print FILENAME " " NR " " FNR " " $0}' a.txt b.txt
a.txt 1 1 a
a.txt 2 2 b
a.txt 3 3 c
a.txt 4 4 d
a.txt 5 5 1
a.txt 6 6 3
a.txt 7 7 5
b.txt 8 1 a
b.txt 9 2 1
läßt In "next" die ersten mit NR angepassten überspringen == FNR
in b.txt und in a.txt
awk 'NR==FNR{a[$0];next}{if($0 in a)print FILENAME " " NR " " FNR " " $0}' a.txt b.txt
b.txt 8 1 a
b.txt 9 2 1
in b.txt aber nicht in a.txt
awk 'NR==FNR{a[$0];next}{if(!($0 in a))print FILENAME " " NR " " FNR " " $0}' a.txt b.txt
b.txt 10 3 2
b.txt 11 4 6
b.txt 12 5 7
awk 'NR==FNR{a[$0];next}!($0 in a)' a.txt b.txt
2
6
7
Wären Sie überrascht, wenn 'a == b' und' b == a' ergaben das gleiche Ergebnis? –
Siehe "Zwei-Datei-Verarbeitung" auf http://backreference.org/2010/02/10/idiomatic-awk/ –