XlsxWriter 在公式单元格上设置格式

XlsxWriter set format on formula cells

经过很长时间的努力。

如何设置已写入公式或将要写入公式的单元格的格式?

除了 write_formula() 之外,每隔一个 write_() 都包含一个格式参数。

例如:

ws.write_number(1,1,quantity, fmt)
ws.write_number(1,2,price, fmt)
# ws.write_formula("C1","=A1*B1",fmt) <-- doesn't exists
ws.write_formula("C1","=A1*B1")

这个有效:

extendedprice = (quantity*price)
ws.write_formula("C1", "=A1*B1", extendedprice, fmt)

我什至发现我可以:

ws.write_number(1,1,quantity, fmt)
if (<price has an error>):
   ws.write_number(1,2,"n/a",fmt)
   ws.write_formula("C1", "=A1*B1", "n/a", fmt)
else:
   ws.write_number(1,2,price,fmt)
   ws.write_formula("C1", "=A1*B1", (quantity*price), fmt)

格式可以像任何其他数据类型一样应用于带有 XlsxWriter 的公式:

import xlsxwriter

workbook = xlsxwriter.Workbook('test.xlsx')
worksheet = workbook.add_worksheet()

my_format = workbook.add_format({'bold': True, 'color': 'red'})

worksheet.write(0, 0, 'Hello', my_format)
worksheet.write(1, 0, 123,     my_format)
worksheet.write(2, 0, '=1+1',  my_format)

worksheet.write('A4', 'World', my_format)
worksheet.write('A5', 456,     my_format)
worksheet.write('A6', '=2+2',  my_format)

workbook.close()

输出: