使用上面的代码报错 new_sheet.append([old_sheet.cell(row=i, column=1).value, row[1], row[2], old_sheet.cell(row=i, column=3).value]) IndexError: tuple index out of range
时间: 2023-06-08 09:07:04 浏览: 59
这个错误通常出现在您使用元组或列表访问非存在的索引时,导致超出范围。对于您给出的代码,错误出在 row 变量中。它可能是因为 row 变量的长度小于 3,在访问 row[2] 时抛出此错误。请检查您的代码,确保 row 变量中至少有 3 个元素。您还可以用 print(row) 来输出 row 的值,以检查它的长度是否正确。
相关问题
从工作表中获取数据并写入下拉框中 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>')
```
这样修改后,用户输入时不会影响下拉框的展示,用户完成输入后才会展示符合条件的选项。
def show_excel(self): style = ttk.Style() style.configure("MyTreeview1.Treeview", rowheight=25, borderwidth=2, relief="solid", font=('Arial', 10)) style.configure("MyTreeview1.Treeview.Heading", font=('Arial', 10, 'bold')) style.layout("MyTreeview1.Treeview", [('MyTreeview1.Treeview.treearea', {'sticky': 'nswe'})]) # 创建表格用于显示第一个工作表 columns1 = next(self.record_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview1 = ttk.Treeview(self.container1, columns=columns1, show="headings", style="MyTreeview1.Treeview") treeview1.grid(row=1, column=3, rowspan=1, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns1: treeview1.heading(col, text=col) treeview1.column(col, width=100, anchor="center") # 显示第一个工作表的内容 for row in self.record_sheet.iter_rows(min_row=2, values_only=True): row_values = [] for cell in row: if cell is None: row_values.append("") elif cell.data_type == 'f': row_values.append(cell.value) else: row_values.append(cell.value) if all(not bool(cell) for cell in row_values): continue treeview1.insert("", tk.END, values=row_values) columns2 = next(self.data_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview2 = ttk.Treeview(self.container1, columns=columns2, show="headings") treeview2.grid(row=3, column=3, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns2: treeview2.heading(col, text=col) treeview2.column(col, width=100, anchor="center") # 显示第二个工作表的内容 for row in self.data_sheet.iter_rows(min_row=2, values_only=True): row_values = [] for cell in row: if cell is None: row_values.append("") elif cell.data_type == 'f': row_values.append(cell.value) else: row_values.append(cell.value) if all(not bool(cell) for cell in row_values): continue treeview2.insert("", tk.END, values=row_values)
这段代码是用于显示 Excel 文件中的两个工作表内容的,其中使用了 ttk.Treeview 控件来实现表格的显示。第一个工作表的列标题和内容通过 self.record_sheet 来获取,第二个工作表的列标题和内容通过 self.data_sheet 来获取。同时,代码还设置了表格列的宽度和对齐方式。如果某一行的所有单元格都是空的,就不会被显示出来。
阅读全文