跳至内容

Odoo 从 XML 文件调用函数的方式

 Odoo 19 中从 XML 文件调用函数的方式

在 Odoo 中,视图通常通过 XML 设计,支持创建各类数据结构与交互界面。尽管 XML 功能强大,但在实际业务场景中(尤其是处理动态或大规模数据集时),往往会面临挑战。例如,在生产环境中安装模块时,可能需要自动更新现有记录 —— 这种场景下,就需要一种能在模块安装阶段触发特定操作的机制。

本文将介绍如何在 XML 文件中使用 <function> 标签,在 Odoo 模块安装过程中调用方法。很多时候,模块安装完成后需立即执行特定操作,而 <function> 标签可触发所需方法或函数,确保这些操作在安装过程中无缝执行。

下面将逐步讲解具体实现方式。

一、核心前提:创建 XML 数据文件

要从 XML 文件调用函数,首先需创建一个 XML 文件(如 product_function.xml),用于定义所需数据与待调用的函数。该文件将作为 “指令容器”,指定模块安装时需执行的方法。

基础 XML 文件框架如下:

<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
   <data noupdate="1">
   </data>
</odoo>

关键参数:noupdate 的作用

noupdate 参数用于控制 “模块更新时,XML 文件中的数据是否重新导入”,具体规则如下:

  • 当设置 noupdate="1" 时(常见于含演示数据的文件):若某条记录在模块更新前已被删除,更新时不会重新导入该记录;但如果数据库中原本就没有这条记录,则会重新导入。
  • 当设置 noupdate="0" 时:无论记录是否存在或被删除,模块更新时都会重新导入该记录。

该参数的核心作用是避免模块更新时重复执行 XML 中的指令(如重复调用函数导致数据冗余)。

注意:需将此 XML 文件(如product_function.xml)添加到模块的 __manifest__.py 文件中,确保模块加载时能识别并执行该 XML 中的内容。

二、两种函数调用场景实操

1. 调用无参数函数

需先在模型中定义无参数函数,再通过 XML 的 <function> 标签调用。

步骤 1:在模型中定义无参数函数

在模块的 Python 模型文件中(如 product_function/product_function.py),继承目标模型并定义函数。示例如下(以继承 “产品模型” 为例):

# -*- coding: utf-8 -*-
from odoo import models, fields, api

class ProductDetails(models.Model):
    _inherit = 'product.product'  # 继承自 Odoo 内置的“产品(product.product)”模型

    @api.model  # 模型级装饰器,无需传入具体记录集即可调用
    def fun_invoke_without_param(self):
        # 函数功能:创建一条名为“test”的产品记录
        self.create(dict(name='test'))

步骤 2:在 XML 中调用无参数函数

在之前创建的 product_function.xml 文件中,使用 <function> 标签指定 “目标模型”与“函数名”,即可调用上述无参数函数:

<function model="product.product" name="fun_invoke_without_param"/>
  • model="product.product":指定函数所属的模型(即上述代码中继承的 product.product);
  • name="fun_invoke_without_param":指定要调用的函数名(需与模型中定义的函数名完全一致)。

2. 调用带参数函数

若函数需传入参数,需先在模型中定义带参函数,再通过 XML 的 <value> 标签传递参数值。

步骤 1:在模型中定义带参数函数

在同一模型文件中,定义接收参数的函数(示例中参数为 name,用于指定产品名称):

@api.model
def fun_invoke_with_param(self, name):
    # 函数功能:根据传入的“name”参数,创建对应的产品记录
    self.create(dict(name=name))

步骤 2:在 XML 中调用带参数函数

在product_function.xml 中,通过 <function> 标签指定模型与函数名,并在标签内部用 <value> 标签传递参数值。示例如下:

<function model="product.product" name="fun_invoke_with_param">
    <value>奶茶demo</value>  <!-- 传递给函数的“name”参数值 -->
</function>
  • 若函数需多个参数,可添加多个 <value> 标签,参数顺序需与函数定义中的参数顺序一致;
  • 示例中传递的参数值为 “奶茶demo”,模块安装后会创建一条名为该名称的产品记录。

三、完整 XML 文件示例

结合上述两种场景,最终的 product_function.xml 文件内容如下:

<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
   <data noupdate="1">
       <!-- 调用无参数函数 -->
       <function model="product.product" name="fun_invoke_without_param"/>
       
       <!-- 调用带参数函数 -->
       <function model="product.product" name="fun_invoke_with_param">
           <value>奶茶demo</value>
       </function>
   </data>
</odoo>

四、执行效果

将模块安装到 Odoo 系统后,上述 XML 中定义的 <function> 标签会自动触发对应的函数:

  • 无参数函数 fun_invoke_without_param 执行,创建一条名为 “test” 的产品记录;
  • 带参数函数 fun_invoke_with_param 执行,创建一条名为 “奶茶demo” 的产品记录。

通过这种方式,可在模块安装阶段自动完成数据初始化、记录更新等操作,无需手动执行代码。

Odoo 从 XML 文件调用函数的方式
中国 Odoo, 苏州远鼎 2026年1月7日
标签
存档