alphaValueDict = OrderedDict.fromkeys(string.ascii_uppercase,range(0)
i = 1
for k,v in alphaValueDict.iteritems():
alphaValueDict[k] = [i]
i += 1
return alphaValueDict
我需要创建一个有序的字典,其中键是字母表中的所有字母,值是1 - 26.我的问题是,如何使用dict理解在一行中执行此操作?
答案 0 :(得分:5)
你可以完全避免字面理解:
>>> import string
>>> dict(zip(string.ascii_lowercase, range(1,27)))
{'a': 1, 'c': 3, 'b': 2, 'e': 5, 'd': 4, 'g': 7, 'f': 6, 'i': 9, 'h': 8, 'k': 11, 'j': 10, 'm': 13, 'l': 12, 'o': 15, 'n': 14, 'q': 17, 'p': 16, 's': 19, 'r': 18, 'u': 21, 't': 20, 'w': 23, 'v': 22, 'y': 25, 'x': 24, 'z': 26}
使用OrderedDict
:
>>> import string
>>> from collections import OrderedDict
>>> OrderedDict(zip(string.ascii_lowercase, range(1,27)))
OrderedDict([('a', 1), ('b', 2), ('c', 3), ('d', 4), ('e', 5), ('f', 6), ('g', 7), ('h', 8), ('i', 9), ('j', 10), ('k', 11), ('l', 12), ('m', 13), ('n', 14), ('o', 15), ('p', 16), ('q', 17), ('r', 18), ('s', 19), ('t', 20), ('u', 21), ('v', 22), ('w', 23), ('x', 24), ('y', 25), ('z', 26)])
只有当你需要做更多的计算来获得键/值或者它是否增强了可读性时,我才会使用dict-comprehension(极端的例子:{noun : age for noun, age in something()}
让你知道我们在谈论什么虽然dict(something())
没有。)
答案 1 :(得分:4)
我接受它:
from string import ascii_uppercase
from collections import OrderedDict
od = OrderedDict((ch, idx) for idx, ch in enumerate(ascii_uppercase, 1))
或者:
from itertools import count, izip
od = OrderedDict(izip(ascii_uppercase, count(1)))
答案 2 :(得分:3)
使用enumerate()
计算字母数:
>>> OrderedDict((k,v+1) for v,k in enumerate(string.ascii_uppercase))
OrderedDict([('A', 1), ('B', 2), ('C', 3), ('D', 4), ('E', 5), ('F', 6), ('G', 7), ('H', 8), ('I', 9), ('J', 10), ('K', 11), ('L', 12), ('M', 13), ('N', 14), ('O', 15), ('P', 16), ('Q', 17), ('R', 18), ('S', 19), ('T', 20), ('U', 21), ('V', 22), ('W', 23), ('X', 24), ('Y', 25), ('Z', 26)])
要回答帖子末尾的问题,词典理解不适合初始化OrderedDict
。 Dict comprehensions只会创建普通的词典,如果你使用它来初始化你的OrderedDict
已经太晚了,你就失去了任何顺序。
答案 3 :(得分:2)
最简单的方法是使用zip和tuple解压缩
import string
{ k: v for k, v in zip(string.ascii_uppercase, xrange(1, len(string.ascii_uppercase)+1))}
已编辑以考虑评论。这是一个班轮,没有dict comp。 只依赖于OrderedDict采用可迭代和zip的强大功能。
OrderedDict(zip(string.ascii_uppercase, xrange(1, len(string.ascii_uppercase)+1)))
答案 4 :(得分:2)
使用基本:
>>> from string import ascii_uppercase
>>> from collections import OrderedDict
一个班轮:
>>> OrderedDict((k, i+1) for i, k in enumerate(ascii_uppercase))
收率:
OrderedDict([('A', 1), ('B', 2), ('C', 3), ('D', 4), ('E', 5), ('F', 6), ('G', 7), ('H', 8), ('I', 9), ('J', 10), ('K', 11), ('L', 12), ('M', 13), ('N', 14), ('O', 15), ('P', 16), ('Q', 17), ('R', 18), ('S', 19), ('T', 20), ('U', 21), ('V', 22), ('W', 23), ('X', 24), ('Y', 25), ('Z', 26)])
答案 5 :(得分:1)
theDict ={chr(y):y-64 for y in range(65,91)
print theDict
输出:
{'A':1,'B':2,......'X':24,'Y':25,'Z':26}
答案 6 :(得分:0)
>>> import string
>>> string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'
>>> s= string.ascii_lowercase
>>> from collections import OrderedDict
>>> odict = OrderedDict()
>>> for count,i in enumerate(s):
... odict[count] = i
...
>>> odict
OrderedDict([(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd'), (4, 'e'), (5, 'f'), (6, 'g'), (7, 'h'), (8, 'i'), (9, 'j'), (10, 'k'), (11, 'l'), (12, 'm'), (13, 'n'), (14, 'o'), (15, 'p'), (16, 'q'), (17, 'r'), (18, 's'), (19, 't'), (20, 'u'), (21, 'v'), (22, 'w'), (23, 'x'), (24, 'y'), (25, 'z')])
答案 7 :(得分:0)
print {chr(ele+97): ele+1 for ele in xrange(26)}
答案 8 :(得分:0)
不使用字典理解,这是一种扩展dict
的变体:
import string
class alph(dict):
def __getitem__(self, key):
if len(key) != 1:
raise ValueError("Not a character.")
return string.ascii_lowercase.index(key.lower()) + 1
处理上部和下部,并抛出ValueError
错误的键。