bk2014111825 2021-09-13 15:49 采纳率: 80%
浏览 188
已结题

python 循环给字典写入数据,打印却只返回最后一条数据问题

场景:多行excel文件,a列名为index,b列名为title,e列名为appkey,g列名为phone。excel文件中有数百行非空数据
需求:将以上值写入字典,格式要求为:
{'appkey': '8628c079ff484d2388a7649fc5bccfca', 'title': '售前咨询', 'index': '2021-09-02-155336', 'phone': '12345678912'}
{'appkey': '8628c079ff484d2388a7649fc5bccfca', 'title': '售前咨询', 'index': '2021-09-02-155336', 'phone': '12345678912'}
...
{'appkey': '8628c079ff484d2388a7649fc5bccfca', 'title': '售前咨询', 'index': '2021-09-02-155336', 'phone': '12345678912'}

问题:现在代码只能输出excel表中最后一行数据,不能满足需求。要求解答最后能返回上述换行、完整的数据

代码片段:


```python
from openpyxl import *

wb = load_workbook('test_1.xlsx')
ws = wb.active
'''
字典套字典
'''
data ={}
for row in range(2,ws.max_row+1):
    #取单元格,值为字符串,格式为列名+行名
    appkey = ws['E' + str(row)].value
    title = ws['B' + str(row)].value
    index = ws['A' + str(row)].value
    phone = ws['G' + str(row)].value
    data.update({'appkey':appkey,'title':title,'index':index,'phone':phone})

print(data)

```

  • 写回答

1条回答 默认 最新

  • 关注

    你所有键都重叠呀,你应该用一个列表承载所有的字典,而不是用字典去做
    字典中每个键只能出现一次
    相当于一个列表,列表中每一个元素都是一个字典
    或者你用enum之类的给每一个字典分配一个编号,然后将这个编号作为键,将字典作为值传入汇总字典

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月21日
  • 已采纳回答 9月13日
  • 创建了问题 9月13日

悬赏问题

  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮