Python3 Openpyxl将表格中多个图表引用数据源工作名修改为当前工作名
时间: 2023-12-03 22:46:16 浏览: 83
Python实现批量更改Excel文件中200多个工作表的内容
要将表格中多个图表引用数据源工作名修改为当前工作名,可以使用 openpyxl 库中的 `Reference` 类和 `parse_addr()` 函数。
首先,可以通过以下代码获取当前工作表的名称:
```python
current_sheet_name = workbook.active.title
```
然后,可以遍历每个工作表,并查找包含图表的单元格。对于每个图表,可以使用 `Reference` 类和 `parse_addr()` 函数来获取其数据源范围。如果该数据源范围中包含引用其他工作表的单元格,则可以使用 `replace()` 函数将这些引用的工作表名称替换为当前工作表的名称。
以下是完整的示例代码:
```python
import openpyxl
workbook = openpyxl.load_workbook('example.xlsx')
current_sheet_name = workbook.active.title
for sheet in workbook:
for chart in sheet._charts:
source_range = chart._source.range
if '!' in source_range:
sheet_name, cell_range = source_range.split('!')
if '[' in cell_range:
start_cell, end_cell = cell_range.split(':')
start_cell_parts = openpyxl.utils.cell.range_boundaries(start_cell)
end_cell_parts = openpyxl.utils.cell.range_boundaries(end_cell)
if start_cell_parts[0] != end_cell_parts[0]:
continue
for i in range(start_cell_parts[1], end_cell_parts[1] + 1):
cell_address = openpyxl.utils.cell.get_column_letter(start_cell_parts[0]) + str(i)
cell_range = cell_range.replace('[' + sheet_name + ']', '[' + current_sheet_name + ']')
chart._source.range = current_sheet_name + '!' + cell_range
chart._source.sheet = sheet
```
这段代码遍历了工作簿中的每个工作表和图表,找到包含引用其他工作表的数据源范围。然后,它使用 `replace()` 函数将引用的工作表名称替换为当前工作表的名称,并将新的数据源范围设置为图表的数据源。最后,它将图表的工作表设置为当前工作表。
阅读全文