我想计算部分语音标签。到目前为止,我已经将部分语音标签(德语)存储在字典中,POS标签的键在哪里,出现次数的值是。当我计算时,我想将“ NN”和“ NE”概括为一个变量“ nouns_in_text”,因为它们都是名词。我做了部分成功。当我的输入文本中同时具有“ NN”和“ NE”时,在这种情况下,我的代码可以正常工作,并且得到正确的结果,即“ NN”和“ NE”的总和。但是问题是,当我有一个输入文本(例如,只有“ NN”而没有“ NE”)时,我得到了KeyError。我需要代码来查看输入文本中是否有“ NN”或“ NE”。如果有“ NN”和“ NE”,则将它们加起来。如果只有“ NN”,则仅返回“ NN”的出现次数,如果只有“ NE”,则返回相同次数。如果既没有“ NN”也没有“ NE”,则返回0或“无”。我想要一个代码,该代码将在以下描述的场景中适用于所有这三种代码,而不会出现错误。# First Scenario: NN and NE are in the Input-TextmyInput = {'NN': 3, 'NE': 1, 'ART': 1, 'KON': 1}# Second Scenario: Only NN is in the Input-Text#myInput = {'NN': 3, 'ART': 1, 'KON': 1}# Third Scenario: Neither NN nor NE are in the Input-Text#myInput = {'ART': 1, 'KON': 1}def check_pos_tag(document): return document['NN'] + document['NE']nouns_in_text = check_pos_tag(myInput)print(nouns_in_text)# Output = If NN and NE are in the input text I get 4 as result# But, if NN or NE are not in the input text I get a KeyError我认为我可以或应该使用if-else条件或try-except块解决此问题。但是我不确定如何实现这些想法...有什么建议吗?提前非常感谢您!:-)
3 回答

慕勒3428872
TA贡献1848条经验 获得超6个赞
使用defaultdict
代替dict
from collections import defaultdictmyInput = defaultdict(int, {'NN': 3, 'ART': 1, 'KON': 1})
这样,您当前的check_pos_tag
功能将可以正常运行而无需进行任何修改
check_pos_tag(myInput)# 3

SMILET
TA贡献1796条经验 获得超4个赞
这应该做到这一点:
def check_pos_tag(document): return document.get('NN', 0) + document.get('NE', 0)
添加回答
举报
0/150
提交
取消