row_list = [] for row in data_sheet[1]: row_list.append(row.value) rowstag = row_list[0]returnData[i] = json.dumps(dict(zip(rowstag, row_list[i])))哪里出现错误
时间: 2023-12-12 20:02:59 浏览: 24
这段代码存在一些问题:
1. 变量 `data_sheet` 没有定义,需要先定义或者传入。
2. 变量 `i` 没有定义,需要先定义或者使用其他变量代替。
3. `returnData` 没有定义,需要先定义或者使用其他变量代替。
4. 缺少循环,需要对 `data_sheet` 进行遍历,获取每一行的数据。
下面是一个可能的修正:
```python
import json
# 定义 data_sheet
data_sheet = ...
# 定义 returnData
returnData = {}
# 遍历 data_sheet 中的每一行
for i, row in enumerate(data_sheet):
row_list = []
for cell in row:
row_list.append(cell.value)
rowstag = row_list[0]
returnData[i] = json.dumps(dict(zip(rowstag, row_list)))
```
注意,这只是一种可能的修正,具体实现还需要根据具体情况进行调整。
相关问题
从工作表中获取数据并写入下拉框中 data_list = [] for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value: data_list.append(cell_value) def on_material_name_keyrelease(event): # 获取用户输入的内容 user_input = self.material_name11.get() if not user_input: # 如果用户没有输入任何内容,则展示所有选项 self.material_name11.configure(values=data_list) else: # 根据用户输入的内容过滤下拉框的选项 filtered_options = [option for option in data_list if user_input in option] if filtered_options: # 如果有符合条件的选项,则更新下拉框的选项并展开下拉框 self.material_name11.configure(values=filtered_options) self.material_name11.event_generate('<Down>') # 根据用户输入的内容在数据表中筛选出对应的行 for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value == user_input: # 找到对应的行后,将第4列的值填入material_qty14中 self.material_qty14.set(self.data_sheet.cell(row=row, column=4).value) break else: # 如果没有符合条件的选项,则关闭下拉框 self.material_name11.event_generate('<Escape>') # 创建标签 self.label10 = ttk.Label(self.container_top, text="PEGA-料号:") self.label10.grid(row=0, column=0, padx=5, pady=5)這段代碼在下拉框輸入内容時會出現開頭有跟表中數據,彈出的下拉框影響用戶正常輸入,修改為用戶正常輸入,下拉框選項也正常彈出
您可以尝试将下拉框的初始化代码放在用户输入内容的判断之后,这样用户输入内容时不会立即展示下拉框的选项,而是等用户输入完成后再展示。具体可以将代码修改为:
```
def on_material_name_keyrelease(event):
# 获取用户输入的内容
user_input = self.material_name11.get()
# 根据用户输入的内容在数据表中筛选出对应的行
for row in range(2, self.data_sheet.max_row + 1):
cell_value = self.data_sheet.cell(row=row, column=1).value
if cell_value == user_input:
# 找到对应的行后,将第4列的值填入material_qty14中
self.material_qty14.set(self.data_sheet.cell(row=row, column=4).value)
break
else:
# 如果没有符合条件的选项,则关闭下拉框
self.material_name11.event_generate('<Escape>')
if not user_input:
# 如果用户没有输入任何内容,则展示所有选项
self.material_name11.configure(values=data_list)
else:
# 根据用户输入的内容过滤下拉框的选项
filtered_options = [option for option in data_list if user_input in option]
# 更新下拉框的选项
self.material_name11.configure(values=filtered_options)
# 展开下拉框
self.material_name11.event_generate('<Down>')
```
这样修改后,用户输入时不会影响下拉框的展示,用户完成输入后才会展示符合条件的选项。
class InventoryApp: def init(self, master): self.master = master master.title("物料进出库统计") self.master.state('zoomed') # 窗口最大化 # 创建左侧面板 self.container = tk.Frame(master) self.container.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) # 创建左上方面板 self.container_top = tk.Frame(self.container) self.container_top.pack(side=tk.TOP, fill=tk.BOTH, expand=True)# 打开Excel文件 self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx") self.record_sheet = self.wb["記錄"] self.data_sheet = self.wb["數據"] # 从工作表中获取数据并写入下拉框中 data_list = [] for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value: data_list.append(cell_value) self.material_name11 = ttk.Combobox(self.container_top, values=data_list) # 创建标签 self.label1 = ttk.Label(self.container_top, text="PEGA-料号:") self.label1.grid(row=0, column=0, padx=5, pady=5) # 添加下拉框控件到界面上 self.material_name11.grid(row=0, column=1, padx=5, pady=5) # 为下拉框控件添加绑定事件 def on_material_name_keyrelease(event): # 获取用户输入的内容 user_input = self.material_name.get() # 根据用户输入的内容过滤下拉框的选项 filtered_options = [option for option in data_list if user_input in option] # 更新下拉框的选项 self.material_name.configure(values=filtered_options) # 展开下拉框 self.material_name.event_generate('<Down>') self.material_name11.bind('<KeyRelease>', on_material_name_keyrelease)self.label6 = ttk.Label(self.container_top, text="品名:") self.label6.grid(row=5, column=0, padx=5, pady=5) self.material_qty6 = ttk.Combobox(self.container_top, values=[]) self.material_qty6.grid(row=5, column=1, padx=5, pady=5)給這段代碼將根據物料名稱下拉輸入框中填寫的内容,去匹配excel表名為數據中第一列相應數據的第5列的值寫道物料品名的下拉框中,沒有就不寫
根据您提供的代码,我注意到在 `on_material_name_keyrelease` 函数中,您使用了 `self.material_name` 而不是 `self.material_name11`,这可能是导致问题的原因。请将以下代码:
```python
# 获取用户输入的内容
user_input = self.material_name.get()
# 根据用户输入的内容过滤下拉框的选项
filtered_options = [option for option in data_list if user_input in option]
# 更新下拉框的选项
self.material_name.configure(values=filtered_options)
# 展开下拉框
self.material_name.event_generate('<Down>')
```
修改为:
```python
# 获取用户输入的内容
user_input = self.material_name11.get()
# 根据用户输入的内容过滤下拉框的选项
filtered_options = [option for option in data_list if user_input in option]
# 更新下拉框的选项
self.material_name11.configure(values=filtered_options)
# 展开下拉框
self.material_name11.event_generate('<Down>')
```
同时,您需要根据用户输入的物料名在 `self.data_sheet` 中查找相应的数据,并将其写入 `self.material_qty6` 中。您可以在 `on_material_name_keyrelease` 函数中添加以下代码:
```python
# 获取用户输入的内容
user_input = self.material_name11.get()
# 在 data_sheet 中查找相应数据
for row in range(2, self.data_sheet.max_row + 1):
if self.data_sheet.cell(row=row, column=1).value == user_input:
# 将数据写入 material_qty6 中
self.material_qty6.configure(values=[self.data_sheet.cell(row=row, column=5).value])
break
else:
# 如果没有找到相应数据,则清空 material_qty6
self.material_qty6.configure(values=[])
```
请注意,`else` 语句块是针对 `for` 循环的,如果 `for` 循环正常结束(即没有执行 `break` 语句),则会执行 `else` 语句块中的代码。
希望这些修改可以解决您的问题。