我试图以条件格式设置数字格式。我已经找到了如何设置字体,边框和填充颜色,但我无法设置数字格式。我公司目前拥有的代码是:openpyxl条件格式设置数字格式

from openpyxl import load_workbook

from openpyxl.styles import PatternFill, Font, Border, Side

from openpyxl.formatting.rule import FormulaRule, DifferentialStyle, Rule

wb = load_workbook(filename='Excel_Templates\MyTemplate.xlsx')

ws = wb.get_sheet_by_name('Sheet1')

red_fill = PatternFill(start_color='FFFF0000', end_color='FFFF0000', fill_type='solid')

pink_fill = PatternFill(start_color='FFFF5050', end_color='FFFF5050', fill_type='solid')

light_pink_fill = PatternFill(start_color='FFFF9B99', end_color='FFFF9B99', fill_type='solid')

blue_fill = PatternFill(start_color='FF0000FF', end_color='FF0000FF', fill_type='solid')

light_blue_fill = PatternFill(start_color='FF0066FF', end_color='FF0066FF', fill_type='solid')

v_light_blue_fill = PatternFill(start_color='FF9BC2E6', end_color='FF9BC2E6', fill_type='solid')

side = Side(style='thin', color='FF000000')

myBorder = Border(left=side, right=side, bottom=side, top=side)

my_white_font = Font(color='FFFFFFFF', size=12)

my_black_font = Font(size=12)

p='E3'

num = 'E8'

denom = 'E9'

ws['{0}'.format(p)] = '=IF({0}/{1} >= 2, {0}/{1}, IF(AND({0}/{1}>=0, {0}/{1} <2),{0}/{1}-1, 1-{0}/{1}))'.format(

num, denom)

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['{0} < -0.5'.format(p)], fill=red_fill, font=my_black_font))

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['AND({0} < -0.25, {0} >=-0.5)'.format(p)], fill=pink_fill,

font=my_black_font))

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['AND({0} < 0, {0} >=-0.25)'.format(p)], fill=light_pink_fill,

font=my_black_font))

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['AND({0} >=0, {0} < 1)'.format(p)], fill=v_light_blue_fill,

font=my_black_font))

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['AND({0} >=1, {0} <= 3)'.format(p)], fill=light_blue_fill,

font=my_white_font))

ws.conditional_formatting.add('{0}'.format(p),

FormulaRule(formula=['{0} > 3'.format(p)], fill=blue_fill,

font=my_white_font))

我想设置的格式与前4种格式没有小数点的百分比,我想将它设置为“+” 0.0的最后两个“X” 。我查看了源代码,找不到一种方法来做到这一点。任何帮助,将不胜感激。我使用Python 3,和Openpyxl 2.3.0与Excel 2010中

更新1:

我用查理的建议更新了我的代码。我补充说:

dxf = DifferentialStyle(fill=blue_fill, font=my_white_font, numFmt='0.00%')

ws.conditional_formatting.add('{0}'.format(p), Rule(formula=['{0} > 3'.format(p)], dxf=dxf))

它给了我下面的错误信息。

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\styles\differential.py", line 57, in __init__

self.numFmt = numFmt

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\descriptors\base.py", line 42, in __set__

raise TypeError('expected ' + str(self.expected_type))

TypeError: expected

更新2:

事实证明,在差分类型的numFmt选项需要NumFmt,其在openpyxl.style.differential定义的一个类的实例。我改变了我的更新1的代码如下:

from openpyxl.styles.differential import NumFmt

dxf = DifferentialStyle(fill=blue_fill, font=my_white_font, numFmt=NumFmt(10, '0.00%'))

r = Rule('expression', formula=['{0} > 3'.format(p)], dxf=dxf)

ws.conditional_formatting.add('{0}'.format(p), r)

现在,这些工作就好了,但是,当我打电话

wb.save("test.xlsx")

我收到以下错误消息

File "C:/TestProj/openpyxl_test.py", line 90, in

wb.save("test.xlsx")

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\workbook\workbook.py", line 263, in save

save_workbook(self, filename)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\excel.py", line 230, in save_workbook

writer.save(filename, as_template=as_template)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\excel.py", line 213, in save

self.write_data(archive, as_template=as_template)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\excel.py", line 87, in write_data

self._write_worksheets(archive)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\excel.py", line 158, in _write_worksheets

xml = sheet._write(self.workbook.shared_strings)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\worksheet\worksheet.py", line 772, in _write

return write_worksheet(self, shared_strings)

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\worksheet.py", line 223, in write_worksheet

for cf in cfs:

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\writer\worksheet.py", line 119, in write_conditional_formatting

if rule.dxf != DifferentialStyle():

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\styles\hashable.py", line 77, in __ne__

return not self == other

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\styles\hashable.py", line 73, in __eq__

return self.key == other.key

File "C:\WinPython-32bit-3.4.3.3\python-3.4.3\lib\site-packages\openpyxl\styles\hashable.py", line 65, in key

self._key = hash(tuple(fields))

TypeError: unhashable type: 'NumFmt'

2015-11-12

tornesi

python字典的键设置条件格式_openpyxl条件格式设置数字格式相关推荐

  1. python字典的键可以用列表吗_python字典多键值及重复键值的使用方法(详解)

    在Python中使用字典,格式如下: dict={ key1:value1 , key2;value2 ...} 在实际访问字典值时的使用格式如下: dict[key] 多键值 字典的多键值形式如下: ...

  2. python 字典键值重复_浅谈python字典多键值及重复键值的使用

    在python中使用字典,格式如下: dict={ key1:value1 , key2;value2 ...} 在实际访问字典值时的使用格式如下: dict[key] 多键值 字典的多键值形式如下: ...

  3. python字典修改键所对应值_详解如何修改python中字典的键和值

    我们知道python中字典是无序的,它们都是通过hash去对应的.一般的如果我们需要修改字典的值,只需要直接覆盖即可,而修改字典的键,则需要使用字典自带的pop函数,示例如下: t = {} t['a ...

  4. python字典的键可以是元组吗_python字典的键可以是元组吗

    python字典的键 字典中的值没有任何限制, 可以是任意Python对象,即从标准对象到用户自定义对象皆可,但是字典中的键是有类型限制的. 不允许一个键对应多个值 必须明确一条原则:每个键只能对应一 ...

  5. python字典改键_python 字典修改键(key)的几种方法

    python 字典修改键(key)的几种方法 python中获取字典的key列表和value列表 # -*- coding: utf-8 -*- # 定义一个字典 dic = {'剧情': 11, ' ...

  6. python 字典修改键(key)的方法

    注意:python中字典的键是不能直接修改,因为键是hash. 间接修改键的key值方法 第一种(推荐): dict={'a':1, 'b':2}dict["c"] = dict. ...

  7. python字典返回键值对列表_返回列表Python dict dictionaries Python 数据结构——字典 返回列表...

    最近研究返回列表,稍微总结一下,以后继续补充: 字典是比列表更先进的一种内置数据结构. "字典"就像现实中的字典一样,每一个单词对应好几个意思.在Python面里就是每一个键对应一 ...

  8. python字典改键_python修改字典键(key)的方法

    python字典中,值可任意更改:但键是唯一的,不支持直接修改.若真的需要修改字典中的键,可通过几种间接方式实现. 新建空白字典. info = {} 给字典添加键-值对. info["x& ...

  9. python字典按照键和值进行排序

    排序首先想到python的sorted()和sort() sort 与 sorted 区别: 1.sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作. 2. li ...

最新文章

  1. K8S调度之pod亲和性
  2. 糟糕!HttpClient 连接池设置引发的一次雪崩!
  3. NOR flash and NAND flash
  4. @所有人 Flink Forward Asia 2020 向您发出议题征集邀请!
  5. 面试加分项!Android权限处理,手慢无
  6. vue页面取ajax返回值,Vue前端交互模式、Promise用法(回调地狱)
  7. (kruskal算法复习+模板)Eddy's picture
  8. python字符串函数的find方法_python字符串的方法与操作大全
  9. python图像转矩阵_python 图像转矩阵,矩阵转图像
  10. 小网站服务器空间,小型网站空间服务器
  11. WINDOWS 服务端 SVN自动部署/一键批处理 SVN 更新项目
  12. 黑苹果固态硬盘_苹果SSD固态硬盘不完全详解
  13. 【Linux 0.11】第九章 块设备驱动程序
  14. Excel表格垂直居中后还是不在单元格中间(探究原因贴)
  15. 单片机c语言或运算,单片机avr c语言位运算 与或非 异或逻辑 运算介绍 详解
  16. Intel 8086处理器
  17. 西欧5800计算器坐标正反算程序
  18. html5class命名规范,开发过程中应该遵守哪些编码规范和class命名规范?
  19. Noise2Noise:Learning Image Restoration without Clean Data读书笔记
  20. 完了,二哥网站的图片挂了

热门文章

  1. 启动项目的时候报驱动错误: not support oracle driver 1.0
  2. (转)SQL Server当中生成一定范围的随机数
  3. linux输入输出重定向详解
  4. Mac串口工具picocom
  5. Wireshake抓包数据怎么看(一)
  6. 别因为要学的太多反而压垮自己
  7. Vue之webpack之Babel
  8. web之Attribute
  9. LED显示驱动(七):图层基本测试总结
  10. 阿里云轻量应用服务器/腾讯云轻量应用服务器如何安装宝塔面板?