首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Pyexcel保存到字典里?

Pyexcel保存到字典里?
EN

Stack Overflow用户
提问于 2016-01-11 15:31:33
回答 2查看 287关注 0票数 1

我正在尝试导入一个简单的xls文件并将数据添加到字典中。我可以把它们加到单子上。问题是字典。

代码语言:javascript
复制
import pyexcel
import pyexcel.ext.xls
book = pyexcel.get_book(file_name="Test.xls")# The external file
names =  {}

names[book["Test"].column[5]] = [book["Sheet1"].column[0]]#Adding the data to the dictionary

下面是错误代码:

代码语言:javascript
复制
names[book["Test"].column[5]] = [book["Sheet1"].column[0]]
TypeError: unhashable type: 'list'
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-01-11 20:43:09

我不使用Pyexcel,所以我的答案是根据两个列表创建一个字典。如果.column[5]是一个键列表,而.column[0]是值列表,那么创建一个名为names的字典:

代码语言:javascript
复制
names = dict(zip(book["Test"].column[5], book["Sheet1"].column[0]))

下面是一个简单的例子所表达的原则:

代码语言:javascript
复制
a = ['a', 'b', 'c']

b = [1,2,3]

dict(zip(a, b))
Out[3]: {'a': 1, 'b': 2, 'c': 3}
票数 1
EN

Stack Overflow用户

发布于 2016-01-11 17:13:49

我有这个答案。看起来有点凌乱,但效果很好。

代码语言:javascript
复制
import pyexcel
import pyexcel.ext.xls
book = pyexcel.get_book(file_name="Test.xls")
names =  {}
a = ' , '.join(book["Test"].column[3])
b = a.split(',')



c = ' ,'.join(book["Test"].column[0])
d = c.split(',')

for index, (value1, value2) in enumerate(zip(d, b)):
     names[value1] = value2
print(names)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34725248

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档