Xlsxwriter生成Excel文件时TypeError异常处理

在使用 XlsxWriter 生成 Excel 文件时,如果遇到 TypeError,通常是因为尝试写入的值或格式与 XlsxWriter 的限制或要求不兼容。

在这里插入图片描述

1、问题背景

在使用 Xlsxwriter 库生成 Excel 文件时,出现 TypeError: “expected string or buffer” 异常。此异常通常是由于某些字符串对象未正确转换为字符串或二进制缓冲区导致,从而导致库无法正确处理数据。

2、解决方案

为了解决此问题,需要确保在将字符串对象传递给 Xlsxwriter 时,将其正确转换为字符串或二进制缓冲区。在 Python 中,可以使用 str() 函数将字符串对象转换为字符串,或使用 BytesIO() 类创建一个二进制缓冲区。

下面提供一个代码示例,演示如何将字符串对象正确转换为字符串或二进制缓冲区,从而解决问题:

from StringIO import StringIO
import datetimefrom django.http import HttpResponse, Http404
import xlsxwriterclass Contact(models.Model):# 省略字段定义def export_xls(request, period=''):# 省略部分代码query = Contact.objects.all().order_by('-enviado_en')if period:query = query.filter(enviado_en__gt=datetime.datetime.now() - deltas[period])stream = StringIO()workbook = xlsxwriter.Workbook(stream, {'in_memory': True})worksheet = workbook.add_worksheet('Contactos')# 设置表头格式header_format = workbook.add_format()header_format.set_align("center")header_format.set_bold()header_format.set_font_name('Arial')# 设置每一列的宽度worksheet.set_column(9, 9, 40)# 写入表头worksheet.write_string(0, 0, str(Contact._meta.get_field('enviado_en').verbose_name), header_format)worksheet.write_string(0, 1, str(Contact._meta.get_field('nombre').verbose_name), header_format)worksheet.write_string(0, 2, str(Contact._meta.get_field('apellido').verbose_name), header_format)worksheet.write_string(0, 3, str(Contact._meta.get_field('email').verbose_name), header_format)worksheet.write_string(0, 4, str(Contact._meta.get_field('telefono').verbose_name), header_format)worksheet.write_string(0, 5, str(Contact._meta.get_field('ciudad').verbose_name), header_format)worksheet.write_string(0, 6, str(Contact._meta.get_field('vehiculo').verbose_name), header_format)worksheet.write_string(0, 7, str(Contact._meta.get_field('kilometraje').verbose_name), header_format)worksheet.write_string(0, 8, str(Contact._meta.get_field('dia_preferente').verbose_name), header_format)worksheet.write_string(0, 9, str(Contact._meta.get_field('mensaje').verbose_name), header_format)# 填充数据body_format = workbook.add_format()body_format.set_font_name('Arial')current_row = 1for contact in query:worksheet.write(current_row, 0, contact.enviado_en.strftime("%d/%m/%Y %H/%M/%S"), body_format)worksheet.write(current_row, 1, contact.nombre, body_format)worksheet.write(current_row, 2, contact.apellido, body_format)worksheet.write(current_row, 3, contact.email, body_format)worksheet.write(current_row, 4, contact.telefono, body_format)worksheet.write(current_row, 5, contact.ciudad, body_format)worksheet.write(current_row, 6, contact.get_vehiculo_display(), body_format)worksheet.write(current_row, 7, contact.get_kilometraje_display(), body_format)worksheet.write(current_row, 8, contact.get_dia_preferente_display(), body_format)worksheet.write(current_row, 9, contact.mensaje, body_format)current_row += 1workbook.close()data = stream.getvalue()response = HttpResponse(content=data, content_type='application/vnd.ms-excel')response['Content-Disposition'] = 'attachment; filename=reporte-%s.xlsx' % datetime.datetime.now().strftime("%Y%m%d%H%M%S")return response

在上面的示例中,我们使用 str() 函数将模型字段的 verbose_name 属性转换为字符串,并将模型字段的 get_display() 方法返回的字符串转换为字符串,以确保这些数据能够正确写入 Excel 文件。

总结

  • 避免写入不支持的数据类型,使用 str()int() 转换非法数据。
  • 对超长字符串和超大数字进行截取或格式化。
  • 确保日期为 datetime.datetime 类型,避免字符串或其他格式。
  • 使用全局异常处理机制和日志记录以捕获潜在问题。

通过这些方法,可以有效避免和处理 XlsxWriter 的 TypeError 异常。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888652.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MATLAB期末复习笔记(下)

目录 五、数据和函数的可视化 1.MATLAB的可视化对象 2.二维图形的绘制 3.图形标识 4.多子图绘图 5.直方图的绘制 (1)分类 (2)垂直累计式 (3)垂直分组式 (4)水平分组式 &…

操作系统学习

问题: 因为想用傲梅来给系统盘扩容,导致无法进入操作系统,报错如下: 无法加载应用程序或操作系统,原因是所需文件丢失或包含错误. 文件:Windowslsystem32lwinload.efi错误代码: 0xc000007b 你需要使用恢复工具。如果…

【环境搭建】Python、PyTorch与cuda的版本对应表

一个愿意伫立在巨人肩膀上的农民...... 在深度学习的世界里,选择合适的工具版本是项目成功的关键。CUDA、PyTorch和Python作为深度学习的三大支柱,它们的版本匹配问题不容忽视。错误的版本组合可能导致兼容性问题、性能下降甚至项目失败。因此&#xff0…

No.26 笔记 | 信息收集与工具实践指南

渗透测试的第一步:信息收集背后的“侦察艺术” 在网络安全的世界里,信息就是武器。 无论是追踪隐藏的漏洞,还是找到不被注意的入口,信息收集就像一场现代化的“谍战片”。而作为渗透测试的开场白,信息收集不仅考验技…

Netty 概述与基本原理

在现代的网络编程中,性能与扩展性成为了构建高效网络应用的核心需求。Netty 是一个用于构建高性能网络应用的异步事件驱动框架,具备高吞吐量、低延迟的特点,被广泛应用于各种需要处理海量连接的场景,例如游戏服务器、即时通讯、分…

mysql为什么用B+树,不用B树和hash

B树每个节点都存储数据和指针,所有节点组成树,叶子结点指针为null,因为每个节点存放数据,而每一页的大小是固定的,这样就会导致存储的键值减少,指针也减少。 哈希索引只支持等值匹配,不支持范围…

HTML5系列(12) 内联式多媒体嵌入指南

前端技术探索系列:HTML5 内联式多媒体嵌入指南 🎥 致读者:探索多媒体嵌入的艺术 👋 前端开发者们, 今天我们将深入探讨 HTML5 的多媒体嵌入技术,学习如何创建灵活、高效且兼容性良好的多媒体内容。 高级…

计算机网络 第5章 运输层

计算机网络 (第8版) 第 5 章 传输层5.4 可靠传输的原理5.4.1 停止等待协议5.4.2 连续ARQ协议 5.5 TCP报文段的首部格式5.6 TCP可靠传输的实现5.6.1 以字节为单位的滑动窗口5.6.2 超时重传时间的选择 5.7 TCP的流量控制5.7.1 利用滑动窗口实现流量控制 5.…

股指期货基差的影响因素有哪些?

在股指期货交易中,有一个重要的概念叫做“基差”。简单来说,基差就是股指期货价格与其对应的现货价格之间的差异。比如,我们现在有IC2401股指期货,它挂钩的是中证500指数。如果IC2401的价格是5244,而中证500指数的价格…

<!DOCTYPE html>的作用是什么

一、背景 从今天开始会不定时的发布一些前端的常见面试题,供大家参考。今天要发布的内容是关于html的面试题的作用是什么。接下来就一起讨论以下吧 二、概念 DOCTYPE 是html5中一种标准通用标记语言的文档类型的声明,它的目的就是为了告诉浏览器应该以…

智能社区服务小程序+ssm(lw+演示+源码+运行)

摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了智能社区服务小程序的开发全过程。通过分析智能社区服务小程序管理的不足,创建了一个计算机管理智能社区服务小程序的方案。文章介绍了智能社区服务…

用人话讲计算机:Python篇!(十一)相对路径与绝对路径

目录 一、计算机中的路径 (1)什么叫路径 (2)绝对路径 (3)相对路径 二、Python中的路径 (1)绝对路径 (2)相对路径 (3)总结 一、…

基于VTX356语音识别合成芯片的智能语音交互闹钟方案

一、方案概述 本方案旨在利用VTX356语音识别合成芯片强大的语音处理能力,结合蓝牙功能、APP或小程序,打造一款功能全面且智能化程度高的闹钟产品。除了基本的时钟显示和闹钟提醒功能外,还拥有正计时、倒计时、日程安排、重要日提醒以及番茄钟…

MFC图形函数学习13——在图形界面输出文字

本篇是图形函数学习的最后一篇,相关内容暂告一段落。 在图形界面输出文字,涉及文字字体、大小、颜色、背景、显示等问题,完成这些需要系列函数的支持。下面做简要介绍。 一、输出文本函数 原型:virtual BOOL te…

【CANoe示例分析】Basic UDP Multicast(CAPL)

1、工程路径 C:\Users\Public\Documents\Vector\CANoe\Sample Configurations 16.6.2\Ethernet\Simulation\UDPBasicCAPLMulticast 在CANoe软件上也可以打开此工程:File|Sample Configurations|Ethernet - Simulation of Ethernet ECUs|Basic UDP Multicast(CAPL) 2、示例目…

【23种设计模式】工厂模式:理论剖析与Java实践

文章目录 工厂模式:理论、Java 实现与实践应用一、工厂模式概述二、简单工厂模式(一)理论介绍(二)代码实现(三)关键步骤(四)流程图 三、工厂方法模式(一&…

【动手学电机驱动】STM32-FOC(10)使用旋钮调节电机转速

STM32-FOC(1)STM32 电机控制的软件开发环境 STM32-FOC(2)STM32 导入和创建项目 STM32-FOC(3)STM32 三路互补 PWM 输出 STM32-FOC(4)IHM03 电机控制套件介绍 STM32-FOC(5&…

使用Pygame创建一个简单的消消乐游戏

消消乐游戏是一种经典的益智游戏,玩家通过交换相邻的方块来形成三个或更多相同颜色的连续方块,从而消除它们。本文将介绍如何使用Python的Pygame库来创建一个简单的消消乐游戏。 准备工作 在开始之前,请确保已安装Pygame库。可以通过以下命…

12.Java 泛型(自定义泛型类、自定义泛型接口、自定义泛型方法、泛型的继承与通配符)

一、泛型引入 1、为什么需要泛型 传统方式存在的问题 不能对加入到集合中的数据类型进行约束 遍历时,需要进行类型转换 泛型的理解与好处 编译时能检查添加元素的类型 能减少类型转换的次数 2、泛型初体验 (1)说明 这里以 Dog 类为例…

最新,Vue 性能提升 400%

最近,Vue 团队核心成员 Johnson Chu 开源一个全新的信号库:alien-signals,这是一个基于 Vue 3.4 响应式系统重写的研究型信号库,可以使 Vue 3.4 的响应式系统性能提升 400%。目前,alien-signals 是所有信号库中最快的实…