首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带句子的Difflib序列匹配器

带句子的Difflib序列匹配器
EN

Stack Overflow用户
提问于 2017-06-02 01:42:47
回答 2查看 665关注 0票数 0

我有以下数据帧

代码语言:javascript
复制
Column1         Column2
tomato fruit    tomatoes are not a fruit
potato la best  potatoe are some sort of fruit
apple           there are great benefits to appel
pear            peer

我已经使用了两种不同的方法:

代码语言:javascript
复制
for i in range(0, len(Column1)):
     store_it = SM(None, Column1[i], Column2[i]).get_matching_blocks()
     print(store_it)

代码语言:javascript
复制
df['diff'] = df.apply(lambda x: diff.SequenceMatcher(None, x[0].strip(), x[1].strip()).ratio(), axis=1) 

我在网上找到的。

第二种方法工作得很好,只是它会尝试匹配整个短语。我如何才能将第一列中的单词与第二列中的句子进行匹配,以便最终给出'Yes‘它们在句子中(或部分)或'No’它们不在句子中。

EN

回答 2

Stack Overflow用户

发布于 2018-10-05 04:08:54

在这一点上,我使用FuzzyWuzzy的部分比率取得了最好的成功。它将给出Column1“番茄水果”和Column2“西红柿不是水果”以及列中其余部分之间的部分%匹配比率。查看结果:

代码语言:javascript
复制
from fuzzywuzzy import fuzz
import difflib

df['fuzz_partial_ratio'] = df.apply(lambda x: fuzz.partial_ratio(x['Column1'], x['Column2']), axis=1)

df['sequence_ratio'] = df.apply(lambda x: difflib.SequenceMatcher(None, x['Column1'], x['Column2']).ratio(), axis=1)

你可以认为任何FuzzyWuzzy分数> 60都是很好的部分匹配,也就是说,是的,Column1中的单词最有可能出现在Column2中的句子中。

第1行-分数67,第2行-分数71,第3行-分数80,第4行-分数75

票数 1
EN

Stack Overflow用户

发布于 2017-06-03 16:52:56

使用set()

Python » Documentation

issubset(other)

设置<= other

测试集合中的每个元素是否都在其他元素中。

例如:

代码语言:javascript
复制
c_set1 = set(Column1[i])
c_set2 = set(Column2[i])
if  c_set1.issubset(c_set2):
    # every in  c_set1 is in  c_set2
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44313964

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档