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

相关文章

QT进行CSV文件初始化与读写操作

《QT进行CSV文件初始化与读写操作》这篇文章主要为大家详细介绍了在QT环境中如何进行CSV文件的初始化、写入和读取操作,本文为大家整理了相关的操作的多种方法,希望对大家有所帮助... 目录前言一、CSV文件初始化二、CSV写入三、CSV读取四、QT 逐行读取csv文件五、Qt如何将数据保存成CSV文件前言

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法

《springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法》:本文主要介绍springboot整合阿里云百炼DeepSeek实现sse流式打印,本文给大家介绍的非常详细,对大... 目录1.开通阿里云百炼,获取到key2.新建SpringBoot项目3.工具类4.启动类5.测试类6.测

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、