Python中有几个用于读写Excel文件的软件包。其中一些包理解格式,有些则不理解。
我想阅读现有的Excel文件并更改某些单元格的背景颜色。我想在这些单元格中添加注释,解释为什么它们的颜色会发生变化。然后我想再把它们救出来。
有没有办法做到这一点?我正在寻找一个纯python解决方案,而不是运行excel的解决方案,因为我需要批量执行此操作。
答案 0 :(得分:0)
我使用pypiwin32如下
import win32.client as win32
app = win32.Dispatch("Excel.Application")
wb = app.Workbooks.Add()
ws = wb.Worksheets("Sheet1")
ws.Range("A1").Interior.Color = 255
ws.Range("A1").AddComment("Comment Text Here")
app.Quit()
答案 1 :(得分:0)
使用openpyxl(https://openpyxl.readthedocs.io/en/2.5/comments.html)相当容易,但请记住,原始注释(如果有的话)将被覆盖。
这是一个设置背景颜色并添加注释的简单片段:
from openpyxl import load_workbook
from openpyxl.comments import Comment
from openpyxl.styles import Color, PatternFill, Font, Border
wb = load_workbook(fname)
ws = wb.active
redFill = PatternFill(start_color='FFFF0000', end_color='FFFF0000', fill_type='solid')
ws['A1'].comment = Comment("Comment for A1","No Such Author")
ws['A2'].fill = redFill
wb.save(fname)