-1
fs = codecs.open('grammar_new.txt', encoding='utf-8')
unidata=[]
d={}
fr=codecs.open('rule.txt', 'w')
for line in fs:
    line_data=line.split()
    for i in range(0,len(line_data)):
       unidata.append(line_data[i])


d = defaultdict(unidata)

执行此代码时将生成错误,因为 d = defaultdict(unidata) TypeError: first argument must be callable..我想将重复的键存储在字典中

4

2 回答 2

9

的第一个参数defaultdict必须是可调用的。您已经传递了一个list不可调用的实例。您想改为传递“列表”类型。

典型的用途是这样的:

d = defaultdict(list)
for k, v in something:
    d[k].append(v)

根据unidata您似乎在评论中提供的内容,我认为您想要:

>>> from collections import defaultdict
>>> unidata = [[u'NP--->', u'N_NNP'], [u'NP--->', u'N_NN_S_NU'], [u'NP--->', u'N_NNP'], [u'NP--->', u'N_NNP'], [u'VGF--->', u'V_VM_VF'], [u'NP--->', u'N_NN']]
>>> d = defaultdict(list)
>>> for k, v in unidata:
...     d[k].append(v)
... 
>>> d
defaultdict(<type 'list'>, {u'VGF--->': [u'V_VM_VF'], u'NP--->': [u'N_NNP', u'N_NN_S_NU', u'N_NNP', u'N_NNP', u'N_NN']})
于 2014-01-29T05:21:17.520 回答
1

我想在字典中存储重复的键

这根本不可能。字典中的键是唯一的。我想你想要的是这样的:

d = defaultdict(list)
with codecs.open('grammar_new.txt', encoding='utf-8') as f:
   for line in f:
      if len(line.rstrip()):
          key,value = line.rstrip().split()
          d[key].append(value)

print(d)

现在d将为每个键包含一个包含相应值的列表。每个键必须是唯一的,但它可以有任意数量的值,可以是重复的。

于 2014-01-29T05:40:08.840 回答