首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何根据odoo中一个Many2one字段的值过滤另一个字段

根据odoo中一个Many2one字段的值过滤另一个字段可以通过定义一个compute函数来实现。下面是一个示例的代码和解释:

代码语言:txt
复制
class MyModel(models.Model):
    _name = 'my.model'

    many2one_field = fields.Many2one('other.model', string='Many2one Field')
    filtered_field = fields.Many2one('other.model', string='Filtered Field',
                                     compute='_compute_filtered_field')

    @api.depends('many2one_field')
    def _compute_filtered_field(self):
        for record in self:
            # 根据many2one_field的值过滤filtered_field
            domain = [('some_field', '=', record.many2one_field.id)]
            records = self.env['other.model'].search(domain)
            # 如果有多个匹配结果,选择第一个作为filtered_field的值
            if records:
                record.filtered_field = records[0]

上述示例中,MyModel 是一个自定义的模型,其中包含两个Many2one字段 many2one_fieldfiltered_field。通过在 filtered_field 字段上定义一个compute函数 _compute_filtered_field,我们可以在 many2one_field 字段值发生变化时实时更新 filtered_field 的值。

_compute_filtered_field 函数中,我们首先根据 many2one_field 的值构建一个域(domain),该域用于过滤 other.model 模型的记录。然后使用 search 方法来查找匹配域条件的记录。如果有多个匹配结果,我们选择第一个作为 filtered_field 的值。最后,我们将更新后的 filtered_field 的值赋给对应的记录。

这样,当 many2one_field 的值发生变化时,filtered_field 的值将根据过滤条件自动更新。

此外,odoo还提供了其他过滤字段的方法,例如domain属性、onchange装饰器等。具体的过滤方式可以根据实际需求选择。

参考链接:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Elasticsearch中将Doc根据A字段排序获得第一个Doc的B字段值的方法

注:本文基于Elasticsearch 6.1.2编写 最近遇到这样一个需求,要通过Elasticsearch将Doc根据A字段降序,然后获得B字段的值,最终根据B字段的值再去做Pipeline Aggregation...先尝试了Max Aggregation,但是Max Aggregation只能获得A字段的最大值。...下面先倒入一段股票数据,date字段代表时间戳,price字段代表当时的价格: POST /_bulk {"index":{"_index":"stock-price","_type":"data"}...index":{"_index":"stock-price","_type":"data"}} {"date":"2018-01-05T10:00:00","price":10} 先分解一下看这个查询如何实现...最后根据算每个bucket的差值,这个会用到Serial Differencing Aggregation 下面是查询代码: GET /stock-price/_search { "size

1.1K20
  • odoo 开发入门教程系列-模型之间的关系(Relations Between Models)

    人们可以很容易地想象一个模型包含客户,另一个模型则包含用户列表。你可能需要参考任何现有业务模型上的客户或用户。...根据的类型对房地产进行分类是一种标准的业务需求,尤其是为了优化过滤。 一个房产可以有一个类型,但同一类型可以分配给多个房产。这得到了many2one概念的支持。...many2one是指向另一个对象的简单链接。...首先,我们不需要所有模型的操作或菜单。某些模型只能通过另一个模型访问。在我们的练习中就是这样的:报价总是通过房产获得的。 其次,尽管property_id字段是必需的,但我们没有将其包含在视图中。...odoo如何知道我们的报价与哪个房产相关?这就是使用odoo框架的一部分魔力:有时候事情是隐式定义的。

    4.5K40

    odoo ORM API学习总结兼orm学习教程

    这个属性的作用就是让同一字段,可以根据不同公司,存储不同的值,假设一个用户属于多个公司,他在不同公司的职务也不一样,此时就可以设置该属性为True。 该值未存储在当前模型表中。...Fields) class odoo.fields.Many2one[源代码] Many2one字段的值是大小为0(无记录)或1(单个记录)的记录集。...参数: comodel_name (str) – 目标模型的名称 inverse_name (str) – 目标模型中反向Many2one字段名称,根据该字段反向查询记录 domain – 用于设置客户端候选值的条件...取决于字段属性,添加一个默认的公司条件 limit (int) – 读取时用的可选限制 注意:odoo不会在当前模型对应表中为One2many,Many2many类型的属性建立对应的表字段,但会为Many2one...Many2many 或者 One2many 字段 related 可以用于引用另一个模型中的 One2many 或Many2many 字段,前提是通过当前模型的一个Many2one关系来实现的。

    13.5K10

    odoo 开发入门教程系列-模型和基本字段

    模型和基本字段 在上一章的末尾,我们创建一个odoo模块。然而,此时它仍然是一个空壳,不允许我们存储任何数据。...ORM 层是odoo的一个关键组件。该层避免了手动写入大部分SQL并提供可扩展性和安全服务. 业务对象被定义为继承于 Model的Python类。可以通过在定义中设置属性来配置model。...model _name中的 . 会被ORM自动化转为_ 。按约定所有的model位于一个名为 models 的目录,并且每个mode被定义为一个Python文件。...有两大类领域字段:‘简单’字段--直接存储在模型表中的原子值,形如Boolean, Float, Char, Text, Date 和Selection, ‘关系型’ 字段--连接相同或者不同模型的记录...required (bool, default: False) 如果为 True, 表示该字段值不能为空。创建记录时必须拥有默认值或给定的值。

    2.4K30

    odoo 开发入门教程系列-计算的字段和变更(Computed Fields And Onchanges)

    然而,我们可能需要给定模型中字段之间的链接。有时,一个字段的值是根据其他字段的值确定的,有时我们希望帮助用户输入数据。...自然地我们将总面积定义这两者的总和,我们将为此使用计算的字段的概念,即给定字段的值将从其他字段的值中计算出来。 到目前为止,字段已直接存储在数据库中并直接从数据库中检索。字段也可以被计算。...在这种情况下,不会从数据库中检索字段的值,而是通过调用模型的方法来动态计算的字段的值。 要创建计算的字段,请创建字段并将其属性compute设置为方法的名称。...') 另一个解决方法是使用store=True属性存储该字段。...description 当数以百万计的记录需要重新计算时,这可能会很快会变得无法承受 还值得注意的是,计算的字段可以依赖于另一个计算的字段。

    3.2K30

    odoo context上下文用法总结

    、过滤条件 视图定义 为设置action打开的tree列表视图,添加默认搜索,搜索条件为 state字段值等于True 过滤器名称,即搜索视图中定义的、元素的name属性值 content 如果fieldName为搜索字段的name属性值,那么...content表示需要搜索的内容,输入内容是字符串,则需要添加引号,形如'test';如果fieldName为搜索过滤器的name属性值,那么content表示布尔值,该值为真,则表示默认开启...> 说明:context属性值中的字典的键值如果为模型中定义的字段名称,则该字段名称必须以元素的形式,出现在模型对应的视图(即不能是内联视图,比如内联Tree列表)中,否则会出现类似错误提示...为可编辑列表视图字段搜索添加查询过滤条件](odoo 为可编辑列表视图字段搜索添加查询过滤条件.md) 用于记录集,传递数据给模型方法 模型设计 #!

    2.2K20

    odoo 开发入门教程系列-基本视图

    在上一章中已经看到,odoo能够为给定模型生成默认视图。实际上,默认视图对于业务应用程序来说是不可接受的。相反,我们至少应该以逻辑的方式组织各个字段。 视图是在带有操作和菜单的XML文件中定义的。...在自定义搜索视图中添加用户可能过滤的字段是非常常见的。 搜索视图还可以包含元素,这些元素充当预定义搜索的开关。...在odoo中,domain对记录上的条件进行编码:domain是用于选择模型记录子集的条件列表。每个条件都是一个包含字段名、运算符和值的三元组。...如果指定字段满足作用于值的运算符的条件,则记录满足条件。...模型定义一个搜索视图 添加过滤和分组 添加以下内容到之前创建就的搜索视图 一个显示avaliable地产的过滤器,也就说,state应该为 “New“ 或者“Offer Received”。

    3.4K40

    odoo Actions学习总结

    所有Action都有两个强制属性: type 当前Action的类别,决定可以使用哪些字段以及如何解释action name action的名称,在客户端的界面中显示对action的简短用户可读描述...context (可选) 传递给视图的附加上下文 domain (可选) 隐式添加到所有视图搜索查询的过滤domain limit (可选) 默认情况下要在列表中显示的记录数。...默认值为“Unnamed”,注意:如果name值为空字符串,则默认为 Unnamed 例如,要使用列表和表单视图打开客户(设置了customer标志的partner): { "type": "ir.actions.act_window...product.product", "views": [[False, "form"]], "res_id": a_product_id, "target": "new", } 另一个例子...所有这些类型都必须在生成的views列表中(至少有一个False view_id) view_ids M2M(技术上不是M2M:添加了一个sequence字段,可以只由一个视图类型组成,没有视图id)

    2.7K30

    odoo 权限管理学习总结

    res_partner表中,那么在odoo中如何区分用户类型以及如何做权限控制的呢?...为了解决上述问题,odoo采用了用户组机制。将用户划分为不同的组(一个用户可以归属多个用户组,一个用户组也可以拥有多个用户),然后给组分配权限,从而实现用户权限的管控及用户类型识别。...可以简单的理解为指定过滤条件,用户只能访问符合本过滤条件的记录,配置为 [(1,'=',1)]则表示匹配所有记录。...=False) 将任意一个perm_method设置为eval="True"、eval="1" ,并将规则授权给用户,规则生效,所以我个人理解,目前记录规则,就是用于过滤记录的,通过domain_force...) ORM字段可以具有提供组列表的groups属性(值为逗号分隔的组XML ID列表,如groups='base.group_user,base.group_system')注意:groups属性值格式

    10.2K20

    Elasticsearch如何聚合查询多个统计值,如何嵌套聚合?并相互引用,统计索引中某一个字段的空值率?语法是怎么样的?

    本文将详细解释一个聚合查询示例,该查询用于统计满足特定条件的文档数量,并计算其占总文档数量的百分比。这里回会分享如何统计某个字段的空值率,然后扩展介绍ES的一些基础知识。...聚合主要分为以下几类:Metric Aggregations(度量聚合):计算数值,例如计数、平均值、最大值、最小值等。例如,value_count 就是一个度量聚合,用于计算特定字段的值的数量。...Bucket Aggregations(桶聚合):将文档分组到不同的桶中。每个桶都可以包含一个或多个文档。例如,terms 聚合将文档根据特定字段的值进行分组。...max:查找数值字段的最大值。extended_stats:获取数值字段的多个统计数据(平均值、最大值、最小值、总和、方差等)。value_count:计算字段的非空值数量。...并相互引用,统计索引中某一个字段的空值率?语法是怎么样的

    22020

    odoo 开发入门教程系列-模块交互

    /14.0/zh_CN/_images/create_inv.gif 每当我们与另一个模块交互时,我们都需要记住模块化。...不幸的是,没有一种简单的方法可以知道如何在Odoo中创建任何给定的对象。大多数时候,有必要查看其模型,以找到所需的字段并提供适当的值。 学习的一个好方法是看看其他模块是如何完成你想做的事情的。...为了创建了发票,我们需要以下信息: 一个 partner_id: 顾客 一个move_type: 它有几个可能的值 journal_id: the accounting journal 这足够创建一个张空发票...create 方法不接受结果集作为字段值。...为此在account.move创建中包含invoice_line_ids字段,这是一个One2many字段。One2many和Many2many使用通用ORM方法中描述的特殊“commands”。

    1.7K10

    odoo 开发入门教程系列-QWeb简史

    此外,PDF报告或网站页面等其他功能需要另一个更灵活的工具:模板引擎。 您可能已经熟悉现有的引擎,如Jinja(Python)、ERB(Ruby) 或Twig(PHP)。...Odoo自带内置引擎:QWeb模板。QWeb是Odoo使用的主要模板引擎。它是一个XML模板引擎,主要用于生成HTML片段和页面。 你可能已经在Odoo见过 看板,其中的记录以卡片状结构显示。...练习--制作一个最小的看版视图 根据上述提供的简单例子,为房产创建一个最小化的看板视图。唯一展示的字段为name....每个字段都有两个属性 value 和raw_value。前者是根据当前用户参数格式化的,后者则是直接通过read()读取的。...在上面的示例中,字段name被添加到元素中,但state在它之外。当我们需要字段的值但不想在视图中显示它时,可以将其添加到元素之外。

    2.2K20

    ODOO配置文件etcodoo.conf配置详解

    1.Dbfilter配置 Odoo是一个多租户系统:一个Odoo系统可以运行并服务于多个数据库实例。它也是高度可定制的,定制(从加载的模块开始)取决于“当前数据库”。 ...这是--db filter的目的之一:它指定如何根据所请求的主机名(域)选择数据库。该值是一个正则表达式,可能包括动态注入的主机名(%h)或访问系统所通过的第一个子域(%d)。 ...[options]   dbfilter = ^%d$   如果直接使用域名作为库名,用 ^%h$ 设置正确的--db过滤器是确保部署安全的重要部分。...当Postgres部署不是本地部署和/或不使用安装默认值时,可以使用数据库选项覆盖此设置。 打包的安装程序将自动创建一个新用户(odoo),并将其设置为数据库用户。 数据库管理界面受管理密码设置保护。...工作进程数量计算 数量规则:(#CPU * 2) + 1 Cron工作者需要CPU 1个工作进程~=6个并发用户 内存大小计算 我们认为20%的请求是繁重请求,而80%是简单请求 一个繁重的工作,当所有的计算字段都设计好了

    7.7K31

    odoo 开发入门教程系列-继承(Inheritance)

    继承(Inheritance) Odoo的一个强大方面是它的模块化。模块专用于业务需求,但模块也可以相互交互。这对于扩展现有模块的功能非常有用。...在介绍特定的Odoo模块继承之前,让我们看看如何更改标准CRUD(创建、检索,更新或删除)方法的行为 Python继承(Python Inheritance) 目标: 不能删除状态不为New、Canceled...为此,我们需要向res.users模型添加一个字段,并调整其视图以显示它。 Odoo提供了两种继承机制来以模块化的方式扩展现有模型。...第一继承机制允许模块通过以下方式修改在另一个模块中定义的模型的行为: 向模型添加字段 覆盖模型中字段的定义 给模型添加约束 给模型添加方法 重写模型中的现有方法 第二种继承机制...odoo中,第一种机制最常用。在我们的例子中,我们希望向现有模型添加一个字段,这意味着我们将使用第一种机制。

    2.3K20

    odoo 开发入门教程系列-一些用户界面

    Odoo有许多微调方式,但通常第一步是确保: 某些字段有默认值 某些字段只读 当记录重复时,某些字段不能被拷贝 在我们的房产业务案例中,我们希望:: 售价只读(往后将自动填充) 当记录重复时,可用日期和售价不能被拷贝...字段定义中,添加 default=X, 其中的X 可以是Python文本值(boolean, integer, float, string) ,也可以是一个以model对象自身为入参并返回一个值的函数:...‘Unknown’,而last_seen 字段默认值为当前时间 练习 -- 设置默认值 添加适当的默认值: 卧室数量默认值为 2 可用日期默认为3个月内 修改 odoo14\custom\estate...预期效果可参考该动画链接:https://www.odoo.com/documentation/14.0/zh_CN/_images/inactive.gif 注意,已存在的记录的active字段默认值为...False 练习--为active字段添加设置 为active字段设置默认值 为 active 字段设置适当的属性值,让它不再出现在页面。

    3K30

    odoo 为form表单视图添加chatter功能

    实践环境 Odoo 14.0-20221212 (Community Edition) 需求描述 如图,给表单新增一个类似聊天的窗口,当记录一些表单活动(本例为自动记录当前记录状态变化) 需求实现 模型定义...odoo14\custom\estate\models\estate_property.py 需要继承mail.thread模型,并为需要追踪的字段设置tracking属性,并设置属性值为真值 #!...\odoo\addons\mail\models\mail_thread.py,其字段命名均以message_开头 tracking 该属性为True或数字时,打开针对该属性所属字段的修改日志-...-当所属字段内容发生变化时,系统会将该字段变化前后的值写入日志中,这个数字的大小影响变更日志在日志中的排序。...\odoo\addons\mail\models\mail_activity.py,其字段命名均以activity_,对应的,模型定义中_inherit 属性也需要添加该模块,如下: _inherity

    79420

    「Odoo 基础教程系列」第三篇——从 Todo 应用开始(2)

    Selection 类型的字段 priority,并且指定了三个可供选择的程度类型,一般情况下,如果一个字段只有固定的几种可选值,通常都会选择使用 Selection 字段,它接受一个元组列表作为参数,...此处我们还给这个字段添加了默认值 todo,表示当一个待办事项被创建后,如果没有指定紧急程度,将默认是待办状态。我们可以为任意类型的字段添加默认值。...这个需求跟时间有关,并且时间是流动(一直在变化)的,所以我们应该要有一个方法在用户每次打开待办事项之前,把这个结果计算好,并且反馈给用户,还好 Odoo 的 ORM 已经为我们实现了相关的机制——计算字段...,只不过多了一个 compute 属性,它的值是计算这个字段值的方法名。...deadline 这个字段的值(我们需要用它的值和当前时间进行比较),如果一个计算字段会用到多个其他字段的值,这里就需要以逗号分隔,将用到的值的字段名依次传入装饰器中。

    1.4K10
    领券