Python xlwt : More than 4094 XFs (styles) 解决方法

    对于大量数据写入excel文件,如果使用了表格样式而且在循环中定义了样式,就是产生了easyxf对象,那么最多只能新建4094个对象,

然后会抛出 More than 4094 XFs (styles)的异常,对于这种情况,简单的解决方案是把样式定义在循环之外,比如:

# -*- coding: utf-8 -*-
from xlrd import open_workbook
from xlwt import Workbook, easyxf

def get_flush():
  book = Workbook()
  sheet = book.add_sheet('test')
  print 'flush_row_data' in dir(sheet)

##  default = easyxf('font: name Arial;')

  for i in xrange(10000):
    try:
      sheet.write(i,1,u'测试' ,easyxf('font: name Arial;'))
    except:
      print i
      raise
    if (i + 1) % 1000 == 0:
      book.save('test.xls')

  book.sace('test.xls')

get_flush()

这样的代码,会抛出异常信息.

改成这样的:

# -*- coding: utf-8 -*-
from xlrd import open_workbook
from xlwt import Workbook, easyxf

def get_flush():
  book = Workbook()
  sheet = book.add_sheet('test')
  print 'flush_row_data' in dir(sheet)

  default = easyxf('font: name Arial;') # define style out the loop will work

  for i in xrange(10000):
    try:
      sheet.write(i,1,u'测试' , default)
    except:
      print i
      raise
    if (i + 1) % 1000 == 0:
      book.save('test.xls')

  book.save('test.xls')

get_flush()

就不用担心异常了.

 

 

转载于:https://www.cnblogs.com/jaw-crusher/p/3741224.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值