微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – 如何从另一个文件中的一个文件中查找单词?

一个文本文件中,我有150个单词.我有一个文本文件,大约有100,000行.

如何检查属于第一个文件的每个单词是否在第二个文件中?

我想过使用grep,但我找不到如何使用它来阅读原始文本中的每个单词.

有没有办法用awk做到这一点?或另一种解决方

我试过这个shell脚本,但它几乎匹配每一行:

#!/usr/bin/env sh
cat words.txt | while read line; do  
    if grep -F "$FILENAME" text.txt
    then
        echo "Se encontró $line"
    fi
done

我发现的另一种方式是:

fgrep -w -o -f "words.txt" "text.txt"

解决方法

你可以使用fgrep -f:
fgrep -f "first-file" "second-file"

或者匹配完整的单词:

fgrep -w -f "first-file" "second-file"

更新:根据评论

awk 'FNR==NR{a[$1];next} ($1 in a){delete a[$1]; print $1}' file1 file2

原文地址:https://www.jb51.cc/linux/394831.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐