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 letterscols = 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 – 在写入csv时使用字典键作为坐标全部内容,希望文章能够帮你解决python – 在写入csv时使用字典键作为坐标所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)