OpenSpace excel-unmerge-before-write
Unmerge merged cells in openpyxl worksheets before writing values to avoid AttributeError
install
source · Clone the upstream repo
git clone https://github.com/HKUDS/OpenSpace
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/HKUDS/OpenSpace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/gdpval_bench/skills/excel-unmerge-before-write" ~/.claude/skills/hkuds-openspace-excel-unmerge-before-write && rm -rf "$T"
manifest:
gdpval_bench/skills/excel-unmerge-before-write/SKILL.mdsource content
Excel Unmerge Before Write
When automating Excel file population with openpyxl, merged cells in templates can cause write failures. This skill provides the pattern to safely handle merged ranges before populating data.
When to Use
- Working with Excel templates that have pre-existing merged cells
- Getting
when trying to write values to certain cellsAttributeError - Needing to populate data in areas that may contain merged ranges
Core Pattern
Before writing values to cells in a worksheet, identify and unmerge any overlapping ranges:
from openpyxl import load_workbook # Load the workbook wb = load_workbook('template.xlsx') ws = wb.active # Unmerge specific ranges before writing ws.unmerge_cells('A46:C46') ws.unmerge_cells('E46:F46') ws.unmerge_cells('I46:K46') # Now safely write values ws['A46'] = 'Value 1' ws['E46'] = 'Value 2' ws['I46'] = 'Value 3' wb.save('output.xlsx')
Step-by-Step Instructions
-
Identify merged ranges in your target worksheet:
print(ws.merged_cells.ranges) -
Unmerge relevant ranges before writing any data to those areas:
for merged_range in ws.merged_cells.ranges: # Optionally filter by area if you only need specific ranges ws.unmerge_cells(str(merged_range)) -
Write your data to the now-unmerged cells:
ws.cell(row=46, column=1, value='Your data') -
Save the workbook:
wb.save('output.xlsx')
Handling Multiple Worksheets
If your workbook has multiple sheets with merged cells:
for sheet_name in wb.sheetnames: ws = wb[sheet_name] for merged_range in list(ws.merged_cells.ranges): ws.unmerge_cells(str(merged_range))
Common Errors
| Error | Cause | Solution |
|---|---|---|
on cell write | Writing to merged cell | Call first |
on range | Invalid range string | Use exact range format like |
| Data overwrites neighbors | Unmerged too broadly | Unmerge only needed ranges |
Best Practices
- Unmerge early: Call
immediately after loading the worksheet, before any write operationsunmerge_cells() - List before unmerging: Capture
before unmerging if you need to know what was mergedws.merged_cells.ranges - Preserve formatting: If merge was for visual formatting, consider re-applying merges after data population if needed
- Test ranges: Verify unmerged ranges don't break template layout expectations
Complete Example
from openpyxl import load_workbook def populate_excel_template(template_path, output_path, data_dict): """Populate an Excel template, handling merged cells safely.""" wb = load_workbook(template_path) ws = wb.active # Unmerge all cells that might conflict with data writes for merged_range in list(ws.merged_cells.ranges): ws.unmerge_cells(str(merged_range)) # Populate data for cell_ref, value in data_dict.items(): ws[cell_ref] = value wb.save(output_path) return output_path