在openpyxl中更改整个列的number_format
发布于2020-12-15 09:58 阅读(1572) 评论(0) 点赞(6) 收藏(5)
在Python中,使用Openpyxl,是否可以更改整个列的数字格式?
目前,我一次只能更改一个单元格:
wb = openpyxl.load_workbook(xlsxFile)
ws = wb['Tasks']
ws.cell(9, 10).number_format = u'#,##0.00€'
对于有格式的格式化,有一个使用范围的简单解决方案:
ws.conditional_formatting.add('I2:%s' % row, openpyxl.formatting.rule.CellIsRule(operator='lessThan', formula=['0'], font=redFont))
我从python脚本填充此xlsx文件中的数据,因此一次可以执行一个单元格,但我想更改number_format多列和几百行的条件格式…
解决方案
采用:
col = ws.column_dimensions['A']
col.number_format = u'#,##0.00€'
请注意,您必须将此格式应用于Excel已创建的单元格。否则,您必须逐个单元地进行迭代。这是文档