Python导出数据到Excel表格-NotImplementedError: formatting_info=True not yet implemented

时间:2022-05-22 18:57:14

在使用Python写入数据到Excel表格中时出现报错信息记录:“NotImplementedError: formatting_info=True not yet implemented”

Python导出数据到Excel表格-NotImplementedError: formatting_info=True not yet implemented

报错分析:看报错信息是未实现的错,其实就是版本不兼容

我在代码中写的是使用xlrd库的方法进行Excel处理,但是我创建的Excel是office 2016版本的,而xlrd只支持2007以前的版本,导致不兼容报错

解决办法1:将模板文件另存为Excel 2003版本的文件格式

解决方法2:使用Python的openpyxl库中的方法进行编写代码

xlrd库与openpyxl库中使用的一些方法说明

(1)、打开一个Excel文件

xlrd中用open_workbook方法:

def open_workbook(filename=None,
logfile=sys.stdout,
verbosity=,
use_mmap=USE_MMAP,
file_contents=None,
encoding_override=None,
formatting_info=False,
on_demand=False,
ragged_rows=False):

open_workbook方法中参数说明:

  • filename参数:是要打开文件的路径及名称
  • logfile:写入消息和诊断的打开文件
  • verbosity:增加写入的日志文件
  • use_mmap:是否使用mmap模块是用启发式方法,如果存在,则使用mmap
  • file_contents:使用了该参数就不要使用filename
  • formatting_info:默认值是“False”,当“True”时,格式信息将从电子表格中读取文件。
  • ragged_rows:默认值“False”表示所有行都用空单元格填充,“True” 表示行的末尾没有空单元格。

openpyxl中用load_workbook方法:

def load_workbook(filename, read_only=False, keep_vba=KEEP_VBA,
data_only=False, keep_links=True)

load_workbook方法中的参数说明:

  • filename:打开文件的路径或对象
  • read_only:为读取而优化,内容无法编辑,false时可以编辑,true时无法编辑
  • keep_vba:保留vba内容
  • data_only:控制带有公式的单元格是具有公式(默认值)还是具有上次Excel读取工作表时存储的值
  • keep_links:是否应保留指向外部工作簿的链接。默认值为True

(2)、复制一个文件都用copy,保存文件都用save

(3)、添加一个sheet工作表

xlrd中用add_sheet方法:

def add_sheet(self, sheetname, cell_overwrite_ok=False):

add_sheet方法参数说明:

  • sheetname:工作表的名称
  • cell_overwrite_ok:默认是false,如果是“True”,则添加的工作表中的单元格将不会因为多次写入时出现异常。

openpyxl中用create_sheet方法:

def create_sheet(self, title=None, index=None):

create_sheet方法中的参数说明,就两个参数:

  • title:插入工作表的名称,str类型
  • index:从第几个开始插入,索引从0开始

(4)、写入数据到Excel表格中

xlrd中用write方法:

 def write(self, r, c, label="", style=Style.default_style):

write方法参数说明:

  • r参数:写入的行
  • c参数:写入的列
  • label:要写入的数据值
  • style:写入的样式

openpyxl中用cell方法:

 def cell(self, row, column, value=None):

cell方法参数说明:

  • row:写入单元格的行
  • column:写入单元格的列
  • value:写入单元格的值

最后贴上两种不同库写入Excel数据的代码:

(1)使用Python的xlrd库实现导出数据到Excel中

    def export_excel(self, names_export):
"""
:param names_export:
:param name_export: 待导出的接口名称,列表形式
:return:
"""
counts_export = len(names_export) # 导出总数
fail_export = [] # 导出失败接口名列表
try:
src = open_workbook(config.src_path+'/report/report_module.xls', formatting_info=True)
destination = copy(src)
dt = datetime.datetime.now().strftime("%Y%m%d%H%M%S") # 当前时间戳
file_path = config.src_path+'/report/'+str(dt)+'.xls'
destination.save(file_path) # 保存模板表格到新的目录下
for name_interface in names_export:
case_interface = operation_db.select_all("select * from case_interface where case_status=1 and "
"name_interface='%s'" % name_interface)
if len(case_interface['data']) != 0 and case_interface['code'] == '':
src = open_workbook(file_path, formatting_info=True)
destination = copy(src)
sheet = destination.add_sheet(name_interface, cell_overwrite_ok=True)
for col in range(0, len(self.field)):
sheet.write(0, col, self.field[col]) # 获取并写数据段信息到sheet中
for row in range(1, len(case_interface['data'])+1):
for col in range(0, len(self.field)):
sheet.write(row, col, '%s' % case_interface['data'][row-1][col]) # 写数据到对应的Excel表中
destination.save(file_path)
elif len(case_interface['data']) == 0 and case_interface['code'] == '':
fail_export.append(name_interface)
else:
fail_export.append(name_interface)
result = {'code': '', 'message': '导出总数%s,失败数:%s' % (counts_export, len(fail_export)),
'data': fail_export}
except Exception as e:
result = {'code': '', 'message': '导出过程异常|导出总数:%s,失败数:%s'
% (counts_export, len(fail_export)), 'data': fail_export}
logging.basicConfig(filename=config.src_path+'/log/syserror.log', level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s')
logger = logging.getLogger(__name__)
logger.exception(e)
return result

(2)使用Python的openpyxl库中的方法实现写入数据到Excel中

    def export_excel(self, names_export):
"""
:param names_export:
:param name_export: 待导出的接口名称,列表形式
:return:
"""
counts_export = len(names_export) # 导出总数
fail_export = [] # 导出失败接口名列表
try:
# src = open_workbook(config.src_path+'/report/report_module.xls', formatting_info=True)
src = load_workbook(config.src_path + '/report/report_module.xlsx', read_only=False)
destination = copy(src)
dt = datetime.datetime.now().strftime("%Y%m%d%H%M%S") # 当前时间戳
file_path = config.src_path+'/report/'+str(dt)+'.xlsx'
destination.save(file_path) # 保存模板表格到新的目录下
for name_interface in names_export:
case_interface = operation_db.select_all("select * from case_interface where case_status=1 and "
"name_interface='%s'" % name_interface)
if len(case_interface['data']) != 0 and case_interface['code'] == '':
src = load_workbook(file_path, read_only=False)
destination = copy(src)
sheet = destination.create_sheet(name_interface, 0)
for col in range(1, len(self.field)+1):
sheet.cell(1, col, self.field[col-1]) # 获取并写数据段信息到sheet中
for row in range(2, len(case_interface['data'])+2):
for col in range(1, len(self.field)+1):
sheet.cell(row, col, '%s' % case_interface['data'][row-2][col-1]) # 写数据到对应的Excel表中
destination.save(file_path)
elif len(case_interface['data']) == 0 and case_interface['code'] == '':
fail_export.append(name_interface)
else:
fail_export.append(name_interface)
result = {'code': '', 'message': '导出总数%s,失败数:%s' % (counts_export, len(fail_export)),
'data': fail_export}
except Exception as e:
result = {'code': '', 'message': '导出过程异常|导出总数:%s,失败数:%s'
% (counts_export, len(fail_export)), 'data': fail_export}
logging.basicConfig(filename=config.src_path+'/log/syserror.log', level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s')
logger = logging.getLogger(__name__)
logger.exception(e)
return result