创建字典,其中键是字母,字符值是1-26使用字典理解

时间:2013-10-23 13:18:57

标签: python dictionary dictionary-comprehension

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理解在一行中执行此操作?

9 个答案:

答案 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错误的键。