我想遍历字典,然后将每个键(字母)重复其值(频率)的次数添加到新列表中。
例如:
输入:{'A':1, 'B':2}
。预期输出:['A', 'B', 'B']
我正在做的事没有用。我要在函数中写些什么来做到这一点?
def get_freq_dict():
freq_dict = {'J' : 1, 'K' : 1, 'Q' : 1, 'X' : 1, 'Z' : 1,\
'B' : 2, 'C' : 2, 'F' : 2, 'H' : 2, 'M' : 2, 'P' : 2,\
'V' : 2, 'W' : 2, 'Y' : 2, '' : 2,\
'G' : 3, 'D' : 4, 'L' : 4, 'S' : 4, 'U' : 4,\
'N' : 6, 'R' : 6, 'T' : 6, 'O' : 8, 'A' : 9, 'I' : 9,\
'E' : 12}
return freq_dict
def bag_of_letters(freq_dict):
freq_lst = []
for key, value in freq_dict.items():
for range in(value):
freq_lst.append(value)
return freq_lst
def main():
freq_dict = get_freq_dict()
freq_lst = bag_of_letters(freq_dict)
print(freq_dict, freq_lst)
main()
答案 0 :(得分:4)
罪魁祸首:
for range in(value):
freq_lst.append(value)
救助者:
for i in range(value):
freq_lst.append(key)
因此:
def get_freq_dict():
freq_dict = {'J' : 1, 'K' : 1, 'Q' : 1, 'X' : 1, 'Z' : 1,\
'B' : 2, 'C' : 2, 'F' : 2, 'H' : 2, 'M' : 2, 'P' : 2,\
'V' : 2, 'W' : 2, 'Y' : 2, '' : 2,\
'G' : 3, 'D' : 4, 'L' : 4, 'S' : 4, 'U' : 4,\
'N' : 6, 'R' : 6, 'T' : 6, 'O' : 8, 'A' : 9, 'I' : 9,\
'E' : 12}
return freq_dict
def bag_of_letters(freq_dict):
freq_lst = []
for key, value in freq_dict.items():
# print(key, value)
for i in range(value):
freq_lst.append(key)
return freq_lst
def main():
freq_dict = get_freq_dict()
freq_lst = bag_of_letters(freq_dict)
print(freq_lst)
main()
输出:
['J', 'K', 'Q', 'X', 'Z', 'B', 'B', 'C', 'C', 'F', 'F', 'H', 'H', 'M', 'M', 'P', 'P', 'V', 'V', 'W', 'W', 'Y', 'Y', '', '', 'G', 'G', 'G', 'D', 'D', 'D', 'D', 'L', 'L', 'L', 'L', 'S', 'S', 'S', 'S', 'U', 'U', 'U', 'U', 'N', 'N', 'N', 'N', 'N', 'N', 'R', 'R', 'R', 'R', 'R', 'R', 'T', 'T', 'T', 'T', 'T', 'T', 'O', 'O', 'O', 'O', 'O', 'O', 'O', 'O', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'I', 'I', 'I', 'I', 'I', 'I', 'I', 'I', 'I', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E']
OR
如果您希望它们很好配对:
for i in range(value):
freq_lst.append([key]*value)
OP :但是我仍然无法打印输出。它不仅提供了我要查找的内容,而且还提供了原始词典在顶部
答案:因为您同时打印了dict
和list
:
print(freq_dict, freq_lst)
只需打印list
即可
print(freq_lst)
编辑2:
使用groupby()
将相似元素组合在一起的另一种更好的方法:
仅附加key
:
for i in range(0, value):
freq_lst.append(key)
然后:
print([list(j) for i, j in groupby(freq_lst)])
输出:
[['J'], ['K'], ['Q'], ['X'], ['Z'], ['B', 'B'], ['C', 'C'], ['F', 'F'], ['H', 'H'], ['M', 'M'],
['P', 'P'], ['V', 'V'], ['W', 'W'], ['Y', 'Y'], ['', ''], ['G', 'G', 'G'],
['D', 'D', 'D', 'D'], ['L', 'L', 'L', 'L'], ['S', 'S', 'S', 'S'], ['U', 'U', 'U', 'U'],
['N', 'N', 'N', 'N', 'N', 'N'], ['R', 'R', 'R', 'R', 'R', 'R'],
['T', 'T', 'T', 'T', 'T', 'T'], ['O', 'O', 'O', 'O', 'O', 'O', 'O', 'O'],
['A', 'A', 'A', 'A', 'A', 'A', 'A', 'A', 'A'],
['I', 'I', 'I', 'I', 'I', 'I', 'I', 'I', 'I'],
['E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E', 'E']]
答案 1 :(得分:0)
您应该改为遍历range
,并附加key
而不是value
:
for key, value in freq_dict.items():
for _ in range(value):
freq_lst.append(key)
或者,您可以使用列表理解:
def bag_of_letters(freq_dict):
return [i for k, v in freq_dict.items() for i in [k] * v]
答案 2 :(得分:0)
您在这里
freq_dict = {'J' : 1, 'K' : 1, 'Q' : 1, 'X' : 1, 'Z' : 1,\
'B' : 2, 'C' : 2, 'F' : 2, 'H' : 2, 'M' : 2, 'P' : 2,\
'V' : 2, 'W' : 2, 'Y' : 2, '' : 2,\
'G' : 3, 'D' : 4, 'L' : 4, 'S' : 4, 'U' : 4,\
'N' : 6, 'R' : 6, 'T' : 6, 'O' : 8, 'A' : 9, 'I' : 9,\
'E' : 12}
def bag_of_letters():
freq_lst = []
for key in freq_dict:
for i in range(0, freq_dict[key]):
freq_lst.append(key)
return freq_lst
def main():
freq_lst = bag_of_letters()
print(freq_lst)
main()
结果['J','K','Q','X','Z','B','B','C','C','F','F',' H”,“ H”,“ M”,“ M”,“ P”,“ P”,“ V”,“ V”,“ W”,“ W”,ecc]
答案 3 :(得分:0)
您可以利用以下事实
如果在不干预字典的情况下调用items(),keys(),values(),iteritems(),iterkeys()和itervalues(),则列表将直接对应。
(如this topic中所示,因此您可以这样做:
import itertools
x = {'A':1, 'B':2}
out = list(map(lambda x,y: [x]*y, x.keys(), x.values()))
print(out) #[['A'], ['B', 'B']]
out = list(itertools.chain.from_iterable(out))
print(out) #['A', 'B', 'B']
我使用itertools
来扁平化列表,如果您不希望import itertools
可以这样做:
out = sum(out,[])
代替
out = list(itertools.chain.from_iterable(out))
答案 4 :(得分:0)
您可以使用Counter
轻松做到这一点:
from collections import Counter
d = {'C': 3, 'B': 2, 'A': 1}
c = Counter(d)
list(c.elements())
# ['C', 'C', 'C', 'B', 'B', 'A']