Odoo12结合python xlwt模块进行Excel打印示例

2023-12-20 04:48

本文主要是介绍Odoo12结合python xlwt模块进行Excel打印示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

测试模块为task_management,git地址为https://github.com/linmao13037/task_managment.git(代码将继续更新)。
task_management模块基于Odoo12社区版实现的一个模块,下载模块之后,秩序将其看作odoo的一个普通模块加载即可,此模块不依赖其他模块,可直接下载安装。


先上效果图:打印界面及下载的Excel内容截图:

打印界面
Excel内容截图


看完效果图之后开始上代码:

task模块,任务模块,内容如下。测试打印数据即从该模型中获取。

# -*- coding: utf-8 -*-from odoo import api, fields, models, _
from odoo.addons import decimal_precision as dp
from odoo.tools import float_compareclass Task(models.Model):_name = 'task'_order = 'id desc'_description = 'Task'name = fields.Char('任务名称', copy=False, required=True)code = fields.Char('任务编号', copy=False)description = fields.Html('问题描述')solution = fields.Html('解决思路')type = fields.Char('任务类型', default="开发")state = fields.Selection([('0', '未开始'), ('1', '进行中'), ('2', '已完成'), ('3', '补充修改'), ('4', '已关闭')],string='状态', siHtmlze=1, help='Priority', default='0', required=True,)priority = fields.Selection([('0', '非常紧急'), ('1', '紧急'), ('2', '一般'), ('3', '正常'), ('4', '不太着急')],string='优先级', size=1, help='Priority', default='3', required=True)module = fields.Char('模块', required=True, default="/")project = fields.Char('项目', required=True, default="/")propose_people = fields.Char('由谁创建', default="/")business_person = fields.Char('由谁负责', default="/")working_hours = fields.Float('预估工时', required=True, default=0)actual_hours = fields.Float('实际工时', default=0)start_time = fields.Date('预计开始时间', required=True, default=fields.Date.today())end_time = fields.Date('预计结束时间')actual_start_time = fields.Date('实际开始时间', required=True, default=fields.Date.today())actual_end_time = fields.Date('实际结束时间')

定义task_export模型即导出Excel模型,如下:

# -*- coding: utf-8 -*-from datetime import datetime, timedelta
from odoo.tools import float_is_zero, float_compare, pycompat
from odoo import models, fields, api, _, SUPERUSER_ID
from odoo.exceptions import UserError, ValidationError
import base64
import xlwt
from io import BytesIOclass TaskExport(models.TransientModel):_name = "task.export"_description = "Task Export"file = fields.Binary('文件')def generate_excel(self, task_ids):workbook = xlwt.Workbook(encoding='utf-8')worksheet = workbook.add_sheet('任务清单')worksheet.col(0).width = (10 * 367)  # 设置表格的宽度worksheet.col(1).width = (30 * 367)worksheet.col(2).width = (15 * 367)worksheet.col(3).width = (15 * 367)style = xlwt.XFStyle()  # 初始化样式font = xlwt.Font()  # 为样式创建字体font.name = '微软雅黑'  # 字体font.bold = True   # 加粗font.height = 20 * 10  # 字体大小style.font = font  # 为样式设置字体# add headerheader = ['任务号', '任务名称', '开始时间', '结束时间']for col in range(len(header)):worksheet.write(0, col, header[col], style)# add datafor row in range(1, len(task_ids) + 1):task_id = task_ids[row - 1]worksheet.write(row, 0, task_id.code if task_id else '')worksheet.write(row, 1, task_id.name if task_id else '')worksheet.write(row, 2, str(task_id.start_time).replace('-', '/') if task_id.start_time else '')worksheet.write(row, 3, str(task_id.end_time).replace('-', '/') if task_id.end_time else '')# savebuffer = BytesIO()workbook.save(buffer)return base64.encodebytes(buffer.getvalue())@api.multidef action_export_data(self):context = dict(self._context or {})task_ids = context.get('active_ids')task_ids = self.env['task'].browse(task_ids)res = self.create({'file': self.generate_excel(task_ids)})value = dict(type='ir.actions.act_url',target='self',url='/web/content?model=%s&id=%s&field=file&download=true&filename=task.xls' % (self._name, res.id),)return value

定义action,绑定到task模块上:

<?xml version="1.0" encoding="UTF-8" ?>
<odoo><record id="excel_task_export_action" model="ir.actions.server"><field name="name">导出Excel文件</field><field name="model_id" ref="task_management.model_task_export"/><field name="binding_model_id" ref="task_management.model_task"/><field name="state">code</field><field name="code">action = env['task.export'].action_export_data()</field></record>
</odoo>

这些代码搞定之后,该引入引入,该加权限加权限(Odoo12的权限机制,csv文件中不定义该模型的权限是不会显示的)然后重启升级,即可看到该下载选项。


在此需要着重感谢两位博主的优质博客:
odoo添加自定义导出按钮:
https://eoyohe.cn/2018/11/02/odoo%E6%B7%BB%E5%8A%A0%E8%87%AA%E5%AE%9A%E4%B9%89%E5%AF%BC%E5%87%BA%E6%8C%89%E9%92%AE/

python的xlwt模块的常用方法:
https://www.cnblogs.com/qiaojushuang/p/7486723.html

这篇关于Odoo12结合python xlwt模块进行Excel打印示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/514816

相关文章

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

Java高效实现PowerPoint转PDF的示例详解

《Java高效实现PowerPoint转PDF的示例详解》在日常开发或办公场景中,经常需要将PowerPoint演示文稿(PPT/PPTX)转换为PDF,本文将介绍从基础转换到高级设置的多种用法,大家... 目录为什么要将 PowerPoint 转换为 PDF安装 Spire.Presentation fo

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal