当我在后端得到 request.POST
时,我会为每个表单创建一个字典。
目前我已经设法通过 request.POST.dict()
将 request.POST (QueryDict) 传递给 dict,正如我在一些 StackOverflow 问题中看到的那样,但是我仍然需要将此字典转换为字典列表,而我没有不知道怎么做。
字典中的每个表单都关联了一个字符串:form-number,我想为每个表单创建一个字典。
当前字典(简化示例):
{'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&', 'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12', 'form-1-jief': 'JUGI&', 'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}
所需的字典列表:
[{'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&'}, {'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12', 'form-1-jief': 'JUGI&'}, {'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}]
我不熟悉 Python,所以我想知道什么是最 Pythonic 的方法来做到这一点?
答案 0 :(得分:1)
您可以像这样创建字典。
dict_1= {'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&', 'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12', 'form-1-jief': 'JUGI&', 'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}
res = {}
for key, value in dict_1.items():
key_ = key.rsplit('-', 1)[0]
res.setdefault(key_, {}).update({key:value})
print(list(res.values()))
输出
[{'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&'}, {'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12', 'form-1-jief': 'JUGI&'}, {'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}]
答案 1 :(得分:1)
def test_function():
test = {'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&', 'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12',
'form-1-jief': 'JUGI&', 'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}
form_num = 0
new_dict = {}
new_list = []
for num, item in enumerate(test):
if int(item[5]) == form_num:
new_dict[item] = test[item]
else:
form_num = int(item[5])
new_list.append(new_dict.copy())
new_dict = {}
new_list.append(new_dict.copy())
print(new_list)
if __name__ == '__main__':
test_function()
输出
[{'form-0-a': 'MIE0158', 'form-0-b': 'ABHD12', 'form-0-jief': 'JUGI&'}, {'form-1-a': 'MIE0158', 'form-1-b': 'ABHD12', 'form-1-jief': 'JUGI&'}, {'form-2-a': 'MIE0158', 'form-2-b': 'ABHD12', 'form-2-jief': 'JUGI&'}]