python - 如何在python中动态更新字典(键/数据)

标签 python loops dynamic xlrd

这是一个测试文件,我正在其中尝试 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 OrderedDict 一次,并且在内部似乎您不断地一次又一次地更改相同键的值,这将保持更改相同的 OrderedDict 对象,最后将相同的 OrderedDict 对象附加到 data_list 中。

您需要为(外循环)的每次迭代创建一个新的data OrderedDict。

尝试类似 -

for i in range(1, sh.nrows):
    data = OrderedDict()
    for j in range(1, sh.ncols+1):
        data[sh.row_values(0)[j-1]] = sh.row_values(i)[j-1]
        data3.append(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)

此外,您似乎没有对 data3 执行任何操作,为什么它在那里?如果不需要,请将其删除。

关于python - 如何在python中动态更新字典(键/数据),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31240568/

相关文章:

通过动态添加一些结构元素来创建结构数组

Python编程使用API​​错误

python - 我使用 virtualenv 是错误的还是这是它的限制?

python - 如何使用Pyramid在Python上获取使用POST提交的数据?

objective-c - 循环直到在 Objective-C 中达到多个条件

python - 迭代 numpy 数组并保持维度

c# - 如何检测 ExpandoObject 上是否存在属性?

python - pickle 一个动态参数化的子类

python - 如何在 Mandlebrot tensorflow 程序中显示图像。当前输出是 <IPython.core.display.Image object>

python - 循环年份,同时跳过某些月份