1. names = ['James John', 'Robert David', 'Paul' ... the list has 5K items]
2.
3. text1 = 'I saw James today'
4. text2 = 'I saw James John today'
5. text3 = 'I met Paul'
6.
7. is_name_in_text(text1,names) # this returns false 'James' in not in list
8. is_name_in_text(text2,names) # this returns 'James John'
9. is_name_in_text(text3,names) # this return 'Paul'
is_name_in_text()如果有名单的是文本搜索。
简单的方法是使用'in
'运算符来检查名称是否在列表中,但列表中有5,000个项目,所以效率不高。我可以将文本拆分为单词,并检查单词是否为in
列表,但如果您有多个单词匹配,则这不起作用。在这种情况下,第7行将失败。
您是否已经有了一种将名称拉出短语的机制? –
是的,我可以做出改变。它也可以在字典中。 '['詹姆斯约翰':'詹姆斯约翰']' – Sam
恰好提出的问题。显示测试数据的好工作。 –