python字典键值存csv_python – 在写入csv时使用字典键作为坐标

我有一个字典,其中单元格坐标为键,所需的单元格内容为值,例如:

dict1 = {'AN32': '2', 'AZ17': '47', ect...}

细胞范围是D4:AZ52

我想把它写成一个csv文件.

我在设计时遇到的问题是字典不一定按字母或数字排序,如上例所示.

我知道如何写入.csv文件

with open('example.csv', 'w') as f:

for i in dict1:

f.write(str(dict1[i]) + ',')

这将按顺序写出值,这意味着它们不在正确的单元格中,我需要它们位于由其键指定的单元格中.

解决方法:

此代码使用列表推导来构建每一行.

首先,我们使用字符串模块中的大写字符串创建列标签列表,然后使用简单的列表解析构建所有列标签的列表.

然后我们使用稍微复杂的列表推导,通过将每个列标签与当前行号(转换为字符串)组合来创建键.该键被传递给dict1的.get()方法以获取与该键相关联的值.我们使用空字符串”作为.get()的第二个arg,这样如果dict中不存在键,我们得到一个空字符串.

然后我们使用.join()方法连接所有这些字符串,用逗号分隔.

from string import uppercase

#Make a list of the column letters

cols = list(uppercase[3:]) + ['A' + c for c in uppercase]

#print(cols)

with open('example.csv', 'w') as f:

for r in range(4, 53):

row = ','.join([dict1.get(c + str(r), '') for c in cols])

f.write(row + '\n')

如果dict1中的值实际上是int而不是字符串,那么在尝试连接它们之前需要将它们转换为字符串.将列表理解更改为

row = ','.join([str(dict1.get(c + str(r), '')) for c in cols])

即使某些值是字符串而某些值是数字,这也可以应对.

标签:python,dictionary,csv,spreadsheet

来源: https://codeday.me/bug/20190706/1399348.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值