我想计算部分语音标签。到目前为止,我已经将部分语音标签(德语)存储在字典中,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-Text
myInput = {'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块解决此问题。但是我不确定如何实现这些想法...有什么建议吗?提前非常感谢您!:-)
梵蒂冈之花
慕勒3428872
SMILET
相关分类