当前位置: 首页 > news >正文

中国网站设计模板下载外发加工单表格模板

中国网站设计模板下载,外发加工单表格模板,手机建站网站,西安公司招聘在使用 XlsxWriter 生成 Excel 文件时,如果遇到 TypeError,通常是因为尝试写入的值或格式与 XlsxWriter 的限制或要求不兼容。 1、问题背景 在使用 Xlsxwriter 库生成 Excel 文件时,出现 TypeError: “expected string or buffer” 异常。此…

在使用 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.yayakq.cn/news/582012/

相关文章:

  • 如何建设商城网站怎么制作网站步骤
  • 广德县住房和城乡建设网站做100个网站
  • html百科网站模板代做网站地图
  • 建设专业网站所需设备优秀产品vi设计手册
  • dede小说网站模板制作一个公司网站用vs怎么做
  • 阿里云域名注册好后怎么建设网站wordpress主题制作pdf
  • 哪个网站是动态郴州市人力资源考试网官网
  • 旅游建设网站目的及功能定位上海网站建设专业公司排名
  • 网站建设培训手册网络平台推广方案
  • 网站建设合同中英文写一个公司的网络设计方案
  • 帝国cms如何做网站地图海报图片怎么设计制作
  • 设计作品欣赏网站wordpress 嵌入 php代码
  • 深圳网站开发工资.我爱你 网站
  • 唐河县住房和城乡建设局网站上海高端设计公司
  • 济南网站建设工作室开发公司副总经理岗位职责
  • 手机显示的网站该怎样设计桂林紧急通知
  • 洛阳直播网站建设外贸企业官网建站
  • 山东省建设项目备案证明网站做网站推广前途
  • 网站的首屏 一屏 二屏是什么意思百度权重排名高的网站
  • 工业设计网站哪家好建设电子商务网站的步骤
  • 深圳做网站那里好建设网站企业网上银行
  • 家庭安全卫士论坛WordPress自己的网站什么做优化
  • PHP网站开发与管理设计心得传奇单职业手机版
  • 哪个网站做logo如何做网站活动封面
  • 承包工地的网站手表网站布局
  • 效能建设网站成都 网站建设培训
  • 简约大气网站首页上海网页制作公司 酒店
  • wordpress数字链接出现404河南网络优化服务
  • 对接标准做好门户网站建设网络公司经营范围怎么填写
  • 青海城乡住房和建设厅网站wordpress如何添加商桥