Můžete prosím zkusit následovat. V případě, že vaše awk podporuje hranice slov.
awk '
/\<apple\>/{
app_found=1
}
/\<mango\>/{
mango_found=1
}
/\<grapes\>/{
grapes_found=1
}
END{
if(app_found && mango_found && grapes_found){
print "All 3 words found."
}
else{
print "All 3 words are NOT present in whole Input_file."
}
}
' Input_file
Upravená odpověď: následující příkaz byl testován se vstupní ukázkou poskytnutou výše a funguje podle potřeby:
awk '
BEGIN { RS = "§" }
{print (/apple/ && /mango/&&/grapes/) ? "match found" : "match not found"}
' demo.txt
Použil jsem znak §
jako oddělovač záznamů, protože takový znak ve vstupu není a protože RS = "\0"
není přenosný. Pokud máte pocit, že by se mohlo stát, že takový §
může nastat ve vstupním souboru, můžete použít níže uvedené přenosné řešení:
awk '
{ i = i $0 }
END { print (i ~ /apple/ && i ~ /mango/ && i ~ /grapes/) ? "match found" : "match not found"}
' demo.txt
Proč Bash `(())` nefunguje uvnitř `[[]]`?
Není možné nainstalovat R 4.0 na Ubuntu 18.04.4 LTS, protože r-base-core vyžaduje verzi libc6 >=2.29?