AttributeError: 'str' object has no attribute 'xlsx'
时间: 2023-11-10 16:06:04 浏览: 347
这个错误提示是因为你在一个字符串对象上调用了 `xlsx` 属性,而字符串对象并没有这个属性。通常情况下,`xlsx` 是指 Excel 文件的扩展名,如果你想要打开一个 Excel 文件,可以使用 Python 的 `openpyxl` 库来读取和写入 Excel 文件。以下是一个简单的示例代码:
```python
import openpyxl
# 打开 Excel 文件
workbook = openpyxl.load_workbook('example.xlsx')
# 获取工作表
sheet = workbook.active
# 读取单元格数据
cell_value = sheet['A1'].value
# 输出单元格数据
print(cell_value)
# 关闭 Excel 文件
workbook.close()
```
相关问题
AttributeError: 'str' object has no attribute 'row'
非常抱歉,我之前的回答中仍然有错误。`row` 是一个字符串,它没有 `row` 属性,所以会抛出错误。
以下是修正后的代码:
```python
import openpyxl
from openpyxl.styles import PatternFill
# 读取原始文件1和文件2
wb1 = openpyxl.load_workbook('原始文件1.xlsx')
wb2 = openpyxl.load_workbook('原始文件2.xlsx')
# 创建新的比较结果文件
output = openpyxl.Workbook()
# 遍历每个工作表
for sheet_name in wb1.sheetnames:
# 获取文件1中当前工作表
ws1 = wb1[sheet_name]
# 获取文件2中当前工作表
ws2 = wb2[sheet_name]
# 创建新的工作表
output_sheet = output.create_sheet(title=sheet_name)
# 复制原始数据到新工作表
for row in ws1.iter_rows(values_only=True):
output_sheet.append(row)
# 获取原始数据的列名
column_names = [cell.value for cell in ws1[1]]
# 将 "SubjectNo" 和 "Line" 列合并作为键列索引
subjectno_index = column_names.index("SubjectNo") + 1
line_index = column_names.index("Line") + 1
# 标记新增行和更新数据
for row in ws2.iter_rows(min_row=2, values_only=True):
subjectno = row[subjectno_index - 1]
line = row[line_index - 1]
key = str(subjectno) + str(line)
is_new_row = True
# 检查是否是新增行
for output_row in output_sheet.iter_rows(min_row=2, max_col=len(column_names), values_only=True):
if output_row[subjectno_index - 1] == subjectno and output_row[line_index - 1] == line:
is_new_row = False
# 检查是否有数据更新
for i in range(len(column_names)):
if output_sheet.cell(row=output_row[0].row, column=i + 1).value != row[i]:
# 更新数据标为金黄色
output_sheet.cell(row=output_sheet.index(output_row) + 1, column=i + 1).fill = PatternFill(start_color='FFFF00', end_color='FFFF00', fill_type='solid')
break
# 新增行标为橙色
if is_new_row:
new_row = [None] * len(column_names)
new_row[subjectno_index - 1] = subjectno
new_row[line_index - 1] = line
output_sheet.append(new_row)
output_sheet.cell(row=output_sheet.max_row, column=1).fill = PatternFill(start_color='FFA500', end_color='FFA500', fill_type='solid')
output_sheet.cell(row=output_sheet.max_row, column=1).value = '新增'
# 在插入的第一列标注为"更新"
output_sheet.insert_cols(1)
output_sheet.cell(row=1, column=1).value = "标注"
output_sheet.cell(row=1, column=1).font = openpyxl.styles.Font(bold=True)
for row in output_sheet.iter_rows(min_row=2, values_only=True):
subjectno = row[subjectno_index - 1]
line = row[line_index - 1]
key = str(subjectno) + str(line)
is_new_row = True
# 检查是否是新增行
for ws2 in wb2:
for row2 in ws2.iter_rows(min_row=2, values_only=True):
if row2[subjectno_index - 1] == subjectno and row2[line_index - 1] == line:
is_new_row = False
break
if not is_new_row:
break
if not is_new_row:
output_sheet.cell(row=output_sheet.index(row) + 1, column=1).value = '更新'
# 保存比较结果文件
output.save("比较结果.xlsx")
```
请确保代码中的文件名正确,对应的原始文件1和原始文件2应该是存在的。此外,代码依赖于 `openpyxl` 库,请确保已经安装了这个库。
现在代码应该可以按照您的要求生成比较结果文件。如果还有其他问题,请随时提问。
AttributeError: 'str' object has no attribute 'get'
这个错误通常发生在尝试在字符串对象上调用`get()`方法时。根据您的代码片段,这可能是因为您尝试在字符串对象`menu_label`上调用`get()`方法。请检查您的代码并确保您正在调用正确的对象上的方法。
如果您正在使用Tkinter创建菜单并使用`Menu`和`MenuItem`对象,请注意,当您使用`add_command()`方法添加菜单项时,它返回的是字符串,而不是`MenuItem`对象。因此,如果您需要在之后访问菜单项,需要在创建时保存它们的引用。以下是一个可能的实现示例:
```
file_menu = Menu(menubar, tearoff=False)
file_menu.add_command(label="PA綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PA綫"))
file_menu.add_command(label="PB綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PB綫"))
menubar.add_cascade(label="文件", menu=file_menu)
# 保存菜单项的引用
self.pa_menu_item = file_menu.entrycget(0, 'label')
self.pb_menu_item = file_menu.entrycget(1, 'label')
def load_excel(self, filename, menu_label):
self.la = menu_label
self.workbook = xl.load_workbook(filename)
self.sheet_names = self.workbook.sheetnames
# 获取当前选择的子菜单文本标签名字
if self.la == self.pa_menu_item:
selected_menu = "PA綫"
elif self.la == self.pb_menu_item:
selected_menu = "PB綫"
# 将其显示在工具栏中的标签中
self.toolbar_label.config(text=selected_menu)
```
在这个实现中,我们保存了菜单项的引用,然后在`load_excel()`方法中将`menu_label`与保存的引用进行比较,以获取当前选择的子菜单文本标签名字。这样就避免了在字符串对象上调用`get()`方法的错误。
阅读全文