odoo 执行Python代码
时间: 2025-05-24 20:53:39 浏览: 17
### 如何在Odoo中执行Python代码
在Odoo中,可以通过多种方式实现Python代码的执行功能。以下是几种常见的方法及其具体实现:
#### 方法一:通过Server Actions(服务器操作)
Odoo 提供了一种内置机制——Server Actions,允许开发者定义并执行自定义的 Python 逻辑。这种机制通常用于自动化业务流程或处理特定事件。
- **配置 Server Action**
可以通过 `Settings -> Technical -> Automation -> Server Actions` 创建一个新的 Server Action,并选择 `'Execute Python Code'` 类型[^1]。
- **示例代码**
下面是一个简单的例子,展示如何在 Server Action 中执行一段 Python 代码来更新某个模型字段:
```python
model = env['your.model.name'] # 替换为实际的模型名
record = model.browse([record_id]) # 获取目标记录
if record:
record.write({'field_name': 'new_value'}) # 更新字段值
```
#### 方法二:通过控制器 (Controller)
如果需要通过 Web 请求触发某些 Python 功能,则可以创建一个自定义控制器。
- **注册路由**
需要在模块中的 `__manifest__.py` 文件声明依赖项,并确保加载了相应的控制器文件。
- **示例代码**
这里提供了一个基本的例子,演示如何接收 HTTP GET 请求并通过 Python 处理数据:
```python
from odoo import http
from odoo.http import request
class MyCustomController(http.Controller):
@http.route('/my_module/my_endpoint', type='json', auth='public')
def my_custom_function(self, **kw):
result = {'status': 'success'}
try:
# 自定义逻辑
partner_model = request.env['res.partner']
partners = partner_model.search([('is_company', '=', True)])
result.update({
'partners_count': len(partners),
'message': f"Found {len(partners)} companies."
})
except Exception as e:
result = {'error': str(e)}
return result
```
#### 方法三:通过 QWeb 报告调用 Python 函数
当生成 PDF 或 HTML 报告时,可能需要用到动态计算的数据。此时可以在报告模板中嵌入 Python 表达式或者调用外部定义好的函数。
- **扩展 Report Class**
定义新的报表类继承基础类,并向上下文中添加额外的方法以便于前端访问[^4]。
- **示例代码**
假设我们有一个名为 `test_report.py` 的文件,其中包含如下内容:
```python
from datetime import date
from odoo.report import report_sxw
class TestWrapped(report_sxw.rml_parse):
def __init__(self, cr, uid, name, context=None):
super(TestWrapped, self).__init__(cr, uid, name, context=context)
self.localcontext.update({
'get_current_date': lambda: date.today().strftime('%Y-%m-%d'),
})
```
接着,在 XML 模板部分可以直接这样引用新增加的功能:
```xml
<p>Today's Date is :<span t-esc="get_current_date()"/></p>
```
---
###
阅读全文
相关推荐


















