
我有兩個文件。
file1.txt
abc def ghi jkl mno pqr
file2.txt
abc ghi abc xyz xyz xyz mno jkl def stu
(列分隔符號是製表符)
我正在嘗試像這樣grepfile1.txt
反對:file2.txt
grep -w -f file1.txt file2.txt
我得到以下輸出:
abc ghi
abc xyz
mno jkl
def stu
但是,我想要的是輸出兩個都的第 1 列和第 2 列file2.txt
有命中file1.txt
,如下所示:
abc ghi
mno jkl
歡迎任何幫助。
謝謝。
擔
答案1
將 的每個值保存file1.txt
在陣列中a
。然後,解析file2.txt
並列印 中同時具有第一個和第二個欄位的行a
。
awk 'NR==FNR{a[$0];next}$1 in a && $2 in a' file1.txt file2.txt
對於 中的任意數量的字段file2.txt
,循環遍歷所有字段並執行檢查。如果其中一個欄位不在 中a
,則繼續下一行,否則列印該行。
awk 'NR==FNR{a[$0];next}{for(i=1;i<=NF;i++){if(!($i in a)){next}}print}' file1.txt file2.txt
答案2
使用我們可以透過建立一個包含 的元素的python
超集來接近 pbm 。b
file1.txt
然後,對於從中讀取的每一行,file2.txt
我們檢查從目前行形成的集合是否是超集 b 的子集。在這種情況下,我們列印 file2.txt 的目前行`
$ python3 -c 'import sys
f1, f2 = sys.argv[1:]
with open(f1) as fh1, open(f2) as fh2:
b = set([l.strip() for l in fh1])
print(*(l.rstrip() for l in fh2 if set(l.strip().split()).issubset(b)), sep="\n")
' file1.txt file2.txt
abc ghi
mno jkl
$ perl -lane '$. == 1 and
%h = map { /(.*)(\n)/ } <STDIN>;
print if ! grep { ! $h{$_} } @F;
' file2.txt < file1.txt
使用 sed,我們將 file1.txt 儲存在保留空間中,然後對於從 File2.txt 讀取的每一行,我們與當前行的所有元素的存在進行比較,並在找到所有元素時列印。
$ sed -Ee '
/\n/{h;d;}
/\s/!{H;d;}
G;h
s/\n.*//;s/\n//;x
:a
s/^\s?(\S+)((\s\S+)?\n.*\n\1(\n|$))/\2/
ta
s/^\n//;tb
D;:b;x
' file1.txt file2.txt
while IFS= read -r l <&3; do
read -r a b <<<"$l"
grep -qFe "$a" file1.txt &&
grep -qFe "$b" file1.txt &&
printf '<%s>\n' "$l"
done 3< file2.txt