if self.data_sheet.cell(row=1, column=1).value is None: self.data_sheet.cell(row=1, column=1, value="PEGA-料号") if self.data_sheet.cell(row=1, column=2).value is None: self.data_sheet.cell(row=1, column=2, value="數量") if self.data_sheet.cell(row=1, column=3).value is None: self.data_sheet.cell(row=1, column=3, value="日期") if self.data_sheet.cell(row=1, column=4).value is None: self.data_sheet.cell(row=1, column=4, value="時間") if self.data_sheet.cell(row=1, column=5).value is None: self.data_sheet.cell(row=1, column=5, value="班別") if self.data_sheet.cell(row=1, column=6).value is None: self.data_sheet.cell(row=1, column=6, value="登記人") if self.data_sheet.cell(row=1, column=7).value is None: self.data_sheet.cell(row=1, column=7, value="單價") if self.data_sheet.cell(row=1, column=8).value is None: self.data_sheet.cell(row=1, column=8, value="品名") if self.data_sheet.cell(row=1, column=9).value is None: self.data_sheet.cell(row=1, column=9, value="儲位") if self.data_sheet.cell(row=1, column=10).value is None: self.data_sheet.cell(row=1, column=10, value="入庫單號")這怎麽優化
时间: 2024-03-27 17:41:00 浏览: 75
可以将这段代码改写为一个循环,避免重复的 if 语句。例如:
```
headers = ["PEGA-料号", "數量", "日期", "時間", "班別", "登記人", "單價", "品名", "儲位", "入庫單號"]
for col in range(1, 11):
if self.data_sheet.cell(row=1, column=col).value is None:
self.data_sheet.cell(row=1, column=col, value=headers[col-1])
```
这样代码更简洁,也更易于维护。
相关问题
from openpyxl import load_workbook, Workbook from openpyxl.styles import PatternFill class ExcelMerger: def __init__(self, input_path, output_path): self.input_path = input_path self.output_path = output_path self.workbook = Workbook() self.sheet = self.workbook.active self.fill = PatternFill(fill_type='solid', start_color='FFFFFF', end_color='FFFFFF') self.row_index = 1 def merge(self): for filename in os.listdir(self.input_path): if not filename.endswith('.xlsx'): continue filepath = os.path.join(self.input_path, filename) workbook = load_workbook(filepath, data_only=True) if '功能点拆分表' not in workbook.sheetnames: continue sheet = workbook['功能点拆分表'] for row in sheet.rows: self.sheet.row_dimensions[self.row_index].height = sheet.row_dimensions[row[0].row].height for cell in row: if cell.value is not None: self.sheet.cell(row=self.row_index, column=cell.column, value=cell.value) self.sheet.cell(row=self.row_index, column=cell.column).fill = cell.fill else: self.sheet.cell(row=self.row_index, column=cell.column).fill = self.fill self.row_index += 1 self.workbook.save(self.output_path)上述修改后的代码仍然出现TypeError: unhashable type: 'StyleProxy'的错误,怎么解决
这个问题通常是由于样式对象(Style)是不可哈希的导致的。在这种情况下,你需要将样式对象转换为可哈希的对象,或者使用其他数据结构来代替字典。
你可以尝试将样式对象转换为字符串,然后将字符串作为键来使用。例如,可以使用`str(style)`来获取样式对象的字符串表示形式,并将其用作字典的键,如下所示:
```
cell_style = {}
...
if cell.has_style:
cell_style[cell.coordinate] = str(cell.style)
...
```
这样就可以避免`TypeError: unhashable type: 'StyleProxy'`错误。
当然,这只是一种解决方案,具体如何修改代码需要根据具体情况而定。
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 来获取。同时,代码还设置了表格列的宽度和对齐方式。如果某一行的所有单元格都是空的,就不会被显示出来。
阅读全文