【发布时间】:2015-09-23 06:55:05
【问题描述】:
这是一个测试文件,我正在尝试使用 excel 读取包,这就是为什么变量被懒惰地命名的原因。我正在尝试从 excel 文件中读取数据并将其转换为 JSON,但我遇到了麻烦遍历数据并将其放入字典中。
import xlrd
from collections import OrderedDict
import json
# Open the workbook and select the first worksheet
wb = xlrd.open_workbook('Test_Book.xlsx')
sh = wb.sheet_by_index(0)
data_list = []
data = OrderedDict()
for i in range(1, sh.nrows):
for j in range(1, sh.ncols+1):
data[sh.row_values(0)[i-1]] = sh.row_values(i)[j-1]
#data[j] = ({sh.row_values(0)[j-(sh.nrows - sh.ncols)] : sh.row_values(j)})
#print("I = "+i.__str__())
#print("J = "+j.__str__())
data_list.append(data)
# Serialize the list of dicts to JSON
j = json.dumps(data_list)
with open('data.json', 'w') as f:
f.write(j)
我尝试了嵌套的 for 循环,但数据的顺序不正确。 键似乎工作正常,但是当我尝试使用数据做同样的事情时,它不起作用。 (这个我不得不手动逐行添加数据,第二部分是我尝试动态添加数据的地方) 这是它的外观。
OrderedDict([('ID', 2.0), ('Make', 'Toyota'), ('Model', 'Corolla'), ('Milage', 15956.0)])
OrderedDict([('ID', 3.0), ('Make', 'Jeep'), ('Model', 'Compass'), ('Milage', 114885.0)])
OrderedDict([('ID', 4.0), ('Make', 'Honda'), ('Model', 'Pilot'), ('Milage', 3830.0)])
这是我的代码执行的样子
OrderedDict([('ID', 5.0), ('Make', 'Subaru'), ('Model', 'Outback'), ('Milage', 20424.0), ('Condition', 'Fair')])
OrderedDict([('ID', 5.0), ('Make', 'Subaru'), ('Model', 'Outback'), ('Milage', 20424.0), ('Condition', 'Fair')])
OrderedDict([('ID', 5.0), ('Make', 'Subaru'), ('Model', 'Outback'), ('Milage', 20424.0), ('Condition', 'Fair')])
【问题讨论】:
-
data是一个引用,所以最后你有一个列表,其中有 3 个引用相同的OrderedDict。您需要在第一个for语句执行data = OrderedDict ()之后重置data。