如何在 Odoo 18 中创建 PDF 报告

article/2025/8/28 16:53:11

如何在 Odoo 18 中创建 PDF 报告

Qweb 是 Odoo 强大的模板引擎,旨在轻松将 XML 数据转换为 HTML 文档。其功能特性包括基于属性的自定义、条件逻辑、动态内容插入及多样化的报告模板选项。这种多功能性使 Qweb 成为制作个性化、视觉吸引力强的报告、电子邮件和文档的理想工具。从财务报表到发票再到复杂业务报告,Qweb 简化了创建流程,确保每份输出既清晰又美观。
在这里插入图片描述

本指南将逐步演示如何在 Odoo 18 中为 “hr.expense” 模型创建自定义 PDF 报告。该过程包括构建 Qweb 模板及配置相应的报告动作,使用户能够直接从 Odoo 界面生成费用明细的 PDF 文件。

分步指南:在 Odoo 18 中创建自定义 PDF 报告

1. 模块结构

模块目录结构如下(以 expense_report_odoo 模块为例):

expense_report_odoo/
├── __manifest__.py
├── models/
│   └── ...
├── report/
│   ├── expense_reports.xml
│   └── expense_report_templates.xml
└── views/└── ...

2. 创建报告动作(XML 文件)

在模块的 “report” 目录下,新建 XML 文件定义报告动作。命名为 expense_reports.xml。该文件将绑定报告与模型,示例如下:

<?xml version="1.0" encoding="UTF-8"?>
<odoo><!-- 费用报告功能 --><record id="action_expense_request_report" model="ir.actions.report"><field name="name">费用报告</field><field name="model">hr.expense</field><field name="report_type">qweb-pdf</field><field name="report_name">expense_report_odoo.report_expense_report_details</field><field name="report_file">expense_report_odoo.report_expense_report_details</field><field name="binding_model_id" ref="hr_expense.model_hr_expense"/><field name="binding_type">report</field></record>
</odoo>

关键字段说明

  1. 名称 (name):报告操作的名称,用于系统内识别(示例:“费用报告”)。
  2. 模型 (model):关联的模型(此处为 “hr.expense”,报告将从中获取数据)。
  3. 报告类型 (report_type):报告类型,可选:
    • qweb-pdf:生成 PDF 报告(本示例使用)。
    • qweb-html:生成 HTML 报告。
    • qweb-text:生成纯文本报告。
  4. 报告名称 (report_name):报告模板的内部名称,格式为模块名.模板ID(示例:expense_report_odoo.report_expense_report_details)。
  5. 报告文件 (report_file):QWeb 模板文件的名称,需与模板 ID 一致。
  6. 绑定模型 ID (binding_model_id):通过 ref 属性关联具体模型,引用模型的 ID,如 hr_expense.model_hr_expense 表示人力资源费用模型。
  7. 绑定类型 (binding_type):绑定类型,report 表示直接绑定到模型记录。

效果

报告操作将在关联模型的 “打印” 菜单中生成新选项。例如,hr.expense 模型的 “打印” 菜单将新增 “费用报告” 选项。
在这里插入图片描述

3. 创建 Qweb 模板(XML 文件)

report 目录下新建 expense_report_templates.xml 定义 PDF 的结构和布局:

<?xml version="1.0" encoding="UTF-8" ?>
<odoo><!-- 费用报告模版 --><template id="report_expense_report_details"><t t-call="web.html_container"><t t-foreach="docs" t-as="o"><t t-call="web.external_layout"><div class="page"><div class="oe_structure"/><h2 style="text-align: center;">费用报告</h2><br/><p>员工姓名:<span t-field="o.employee_id.name"/></p></div></t></t></t></template>
</odoo>

模板解析

  • template_id:需与报告操作中 report_name 的后缀一致(示例:report_expense_report_details)。
  • t-foreach 循环:遍历模型记录(docs 为当前上下文中的记录集),t-as="o" 将每条记录赋值给变量 o
  • t-call=“web.external_layout”:引用 Odoo 默认的外部布局(包含页眉、页脚等样式)。
  • 字段渲染:使用 t-field 标签动态插入数据(如 o.employee_id.name 表示员工姓名)。

注册文件

注:在 __manifest__.py 中注册文件,确保模块清单文件中包含:

'data': ['report/expense_reports.xml','report/expense_report_templates.xml',
],

此模板通过循环 docs(当前记录集)生成每页报告,调用标准布局 web.external_layout,并插入员工姓名字段。
在这里插入图片描述

总结

通过 Qweb 在 Odoo 18 中创建 PDF 报告的核心是结合报告操作(ir.actions.report)和 QWeb 模板。报告操作定义数据来源和输出类型,QWeb 模板负责内容布局和动态数据渲染。这种方式灵活且易于扩展,可根据业务需求定制复杂报告,提升数据展示的规范性和可读性。


http://www.hkcw.cn/article/ckydEdvarq.shtml

相关文章

【面板数据】上市公司供应链网络地位数据(2001-2024年)

企业是产业链供应链的微观主体&#xff0c;其供应链网络布局是增强产业链供应链稳定性的重中之重&#xff0c;企业在供应链网络中的地位&#xff0c;已成为衡量其市场影响力和风险承受能力的重要指标。本次是上市公司供应链网络地位数据&#xff0c;数据年份为2001-2024年。 一…

EasyFileCount(文件查重工具) v3.0.5.1 便携版

EasyFileCount 是一款免费方便、快捷的文件管理软件&#xff0c;采用Java开发&#xff0c;主打一个清爽简洁、安全无害的使用体验&#xff0c;支持多盘高性能扫描。遍历扫描文件夹的速度还算比较快的&#xff0c;当然所谓的快慢取决于CPU、系统、硬盘种类、文件或文件夹的数量等…

【在线五子棋对战】一、项目简介 环境搭建

文章目录 Ⅰ. 项目简介Ⅱ. 开发环境Ⅲ. 核心技术Ⅳ. 环境搭建① CentOS-7.6环境搭建1、安装wget工具2、更换软件源3、安装第三方软件源4、安装lrzsz传输工具5、安装高版本gcc/g编译器6、安装gdb调试器7、安装git8、安装cmake9、安装boost库10、安装Jsoncpp库11、安装MySQL数据库…

MFC坦克大战游戏制作

MFC坦克大战游戏制作 前言 现在的游戏制作一般是easyx&#xff0c;有没有直接只用mfc框架的&#xff0c;笔者研究了一番&#xff0c;做出了一个雏形&#xff0c;下面把遇到的问题总结出来 一、MFC框架制作游戏 初步设想&#xff0c;MFC可以选用 对话框 或者 单文档 结构&…

12:遨博机器人SDK二次开发

一、流程步骤 1.获取当前点关节坐标 2.走当前点关节坐标 1.获取目标点x,y,z&#xff08;位置坐标&#xff0c;以m为单位&#xff0c;需要*1000变成mm&#xff09;和四元素&#xff08;位姿坐标&#xff09; 2.四元素→欧拉角&#xff08;弧度制&#xff09; 3.欧拉角&#x…

XPlifeapp:高效打印,便捷生活

在数字化时代&#xff0c;虽然电子设备的使用越来越普遍&#xff0c;但打印的需求依然存在。无论是学生需要打印课表、资料&#xff0c;还是职场人士需要打印名片、报告&#xff0c;一个高效便捷的打印软件都能大大提高工作效率。XPlifeapp就是这样一款超级好用的手机打印软件&…

DeepSeekMath:突破开放式语言模型中数学推理能力的极限

摘要 由于数学推理具有复杂且结构化的特性&#xff0c;这对语言模型构成了重大挑战。在本文中&#xff0c;我们介绍了 DeepSeekMath 7B 模型&#xff0c;该模型在 DeepSeek-Coder-Base-v1.5 7B 模型的基础上&#xff0c;使用从 Common Crawl 获取的 1200 亿个与数学相关的标记…

OpenBayes 教程上新丨谷歌发布 MedGemma,基于 Gemma 3 构建,专攻医学文本与图像理解

在 Google I/O 2025 大会上&#xff0c;公司 CEO Sundar Pichai 在活动首日的主题演讲中便分享了多项创新&#xff0c;例如 Gemini 2.5 的全系列升级&#xff0c;Agent Mode 上线 Chrome&#xff0c;编码智能体 Jules 开启公测&#xff0c;Android XR 正式版亮相等等。而在一众…

【数据结构】栈和队列(下)

目录 一、队列&#xff08;先进先出的特殊结构&#xff09; 队列的概念与结构 二、代码实现 1、定义队列的结构 2、队列的初始化操作 3、判空操作 4、入队操作 5、出队操作 6、取队头、队尾操作 7、队列销毁操作 8、队列中有效数据个数 9、测试代码 10、.h文件 一…

基于卫星遥感数据识别互花米草及原生植被分布及生长的技术原理、关键方法

通过卫星遥感监测生态保护红线&#xff0c;基于卫星遥感数据识别互花米草及原生植被&#xff08;如芦苇&#xff09;的分布、面积及生长状况&#xff0c;主要利用不同植被类型的光谱特征差异、物候周期差异和遥感影像处理技术实现。 上星图地球开放平台获取更多生态保护解决方案…

可视化图解算法47:包含min函数的栈

1. 题目 牛客网 面试笔试 TOP101 | LeetCode 155. 最小栈 描述 定义栈的数据结构&#xff0c;请在该类型中实现一个能够得到栈中所含最小元素的 min 函数&#xff0c;输入操作时保证 pop、top 和 min 函数操作时&#xff0c;栈中一定有元素。 此栈包含的方法有&#x…

windows系统下通过visual studio使用clang tooling

vs吃上clang tooling 通过源码编译clang安装必备软件GnuWin32 Tools&#xff1a; 拉取/下载git仓库编译 在项目中使用clangTool 通过源码编译clang 教程参考安装教程 作者本人亲身使用流程&#xff1a; 安装必备软件 Git&#xff1a;作者已经有了&#xff0c;自己查CMake&am…

路由器、网关和光猫三种设备有啥区别?

无论是家中Wi-Fi信号的覆盖&#xff0c;还是企业网络的高效运行&#xff0c;路由器、网关和光猫这些设备都扮演着不可或缺的角色。然而&#xff0c;对于大多数人来说&#xff0c;这三者的功能和区别却像一团迷雾&#xff0c;似懂非懂。你是否曾疑惑&#xff0c;为什么家里需要光…

攻防世界János-the-Ripper

打开压缩包是一个文件&#xff0c;用010Editor打开可以发现里面有隐藏文件flag.txt 此时想到分离文件&#xff0c;利用binwalk工具 利用binwalk生成出的是一个压缩包&#xff0c;解压缩但是发现竟然解压需要密码 这里就可以开始暴力破解密码了&#xff0c;这里我用的是ARCHPR工…

酷派Cool20/20S/30/40手机安装Play商店-谷歌三件套-GMS方法

酷派Cool系列主打低端市场&#xff0c;系统无任何GMS程序&#xff0c;也不支持直接开启或者安装谷歌服务等功能&#xff0c;对于国内部分经常使用谷歌服务商店的小伙伴非常不友好。涉及机型有酷派Cool20/Cool20S /30/40/50/60等旗下多个设备。好在这些机型运行的系统都是安卓11…

本地部署大模型llm+RAG向量检索问答系统 deepseek chatgpt

项目视频讲解: 本地部署大模型llm+RAG向量检索问答系统 deepseek chatgpt_哔哩哔哩_bilibili 运行结果:

并查集 c++函数的值传递和引用传递 晴神问

目录 学校的班级个数 手推7个班级&#xff0c;答案17&#xff1f;怀疑人生 破案了&#xff0c;应该是6个班。 破案了&#xff0c;原来写的是 unionxy(a, b, father); c if两个数同时为正或为负 简洁写法 可以用位运算&#xff1f; c可以这样赋值吗&#xff1f;ab2 典型…

Dynamics 365 Business Central AI Sales Order Agent Copilot

#AI Copilot# #D365 BC 26 Wave# 最近很多客户都陆续升级到 Dynamics 365 Business Central 26 wave, Microsoft 提供一个基于Copilot 的Sales Order Agent&#xff0c;此文将此功能做个介绍. Explorer: 可以看到26版本上面增加了这样一个新图标。 Configuration: 配置过程…

Webug4.0靶场通关笔记03- 第3关SQL注入之时间盲注(手注法+脚本法 两种方法)

目录 一、源码分析 1.分析闭合 2.分析输出 &#xff08;1&#xff09;查询成功 &#xff08;2&#xff09;查询失败 &#xff08;3&#xff09;SQL语句执行报错 二、第03关 延时注入 1.打开靶场 2.SQL手注 &#xff08;1&#xff09;盲注分析 &#xff08;2&#xf…

NodeJS 基于 Koa, 开发一个读取文件,并返回给客户端文件下载,以及读取文件形成列表和文件删除的代码演示

前言 在上一篇文章 《Nodejs 实现 Mysql 数据库的全量备份的代码演示》 中&#xff0c;我们演示了如何将用户的 Mysql 数据库进行备份的代码。但是&#xff0c;这个备份&#xff0c;只是备份在了服务器上了。 而我们用户的真实需求&#xff0c;是需要将备份文件下载到本地进行…