AttributeError: 'Workbook' object has no attribute 'append'
时间: 2023-11-10 20:07:08 浏览: 420
这个错误通常是因为没有使用正确的方法来向工作簿中添加数据。`Workbook`对象没有`append`方法。正确的方法是使用工作表对象的`append`方法来添加行。
以下是一个示例代码,向工作簿中的第一个工作表添加一行数据:
```
import openpyxl
# 打开工作簿
workbook = openpyxl.load_workbook('example.xlsx')
# 选择第一个工作表
worksheet = workbook[workbook.sheetnames[0]]
# 添加一行数据
worksheet.append(['Data 1', 'Data 2', 'Data 3'])
# 保存工作簿
workbook.save('example.xlsx')
```
相关问题
AttributeError: 'Worksheet' object has no attribute 'append'
这个错误通常是因为使用了错误的方法。在Python中,`append`方法只能用于列表,而`Worksheet`对象不支持`append`方法。
如果你想在一个`Worksheet`中添加数据,可以使用`cell()`方法来指定单元格并设置其值。例如:
```python
import openpyxl
# 打开工作簿
workbook = openpyxl.load_workbook('example.xlsx')
# 选择工作表
worksheet = workbook['Sheet1']
# 在A1单元格中设置值
worksheet.cell(row=1, column=1, value='Hello World')
# 保存工作簿
workbook.save('example.xlsx')
```
这将在`Sheet1`工作表的A1单元格中设置值为`Hello World`。
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` 库,请确保已经安装了这个库。
现在代码应该可以按照您的要求生成比较结果文件。如果还有其他问题,请随时提问。
阅读全文