前一篇介绍了如何在视图和表单中添加字段。本节内容,我们讨论下如何在明细中加字段。

  我想在销售页面明细中增加税额字段,这在表sale.order.line中已经存在,在此仅用来演示。

  odoo的明细一般都是One2many字段,通过Tab页或直接以列表形式展示在表单视图中,如下:  

    

  主要关注的是字段名order_line,属于模型sale.order,是一个one2many字段,关联的是sale.order.line模型。展示的列表如下:

  

  订单行如图所示,列表中所展示的字段,都是sale.order.line模型中的字段。

  因此,我们要想在订单行(以下简称明细)中增加字段,就需要在对应的sale.order.line模型中添加字段。

  在models目录中创建sale_order_line_extension.py文件,在__init__.py文件中引用。

  sale_order_line_extension.py中代码如下:

 # -*- coding:utf-8 -*-
"""销售订单行扩展""" from odoo import models, fields, api # 销售订单行扩展
class SaleOrderLineExtension(models.Model):
"""销售订单行扩展"""
_inherit = 'sale.order.line' # 税额
x_price_tax = fields.Monetary(string='税额', compute='_get_line_price_tax') # 获取订单行税额
@api.multi
def _get_line_price_tax(self):
"""
获取订单行税额
:return: None
"""
if self:
# self是订单行对象数据集
# 遍历数据集
for line in self:
# 税率
tax = sum(line.tax_id.mapped('amount')) / 100
# 单价
price = line.price_unit
# 数量
number = line.product_uom_qty
# 税额 = 不含税销售额 × 税率
# 不含税销售额 = 含税价 / (1 + 税率)
line.x_price_tax = (price / (1 + tax) * tax) * number

  增加的税额字段x_price_tax是一个Monetary字段,在odoo中主要用于货币问题,需要定义一个currency_id字段,并在xml中引用

currency_id = fields.Many2one('res.currency', 'Currency')
<tree>
<field name="currency_id" invisible="1" />
<field name="x_price_tax" />
</tree>

  在xml中增加currency_id字段后,主要效果是出现了货币符号。(个人观点,不知是否正确,供参考)

  在源码的tree中已经存在该字段,不需要添加,上面仅用于演示。

  另外,x_price_tax字段是一个计算字段,这种类型的字段不会存储到数据库中,如果需要存储,可以增加stroe=True属性。

x_price_tax = fields.Monetary(string='税额', store=True, compute='_get_line_price_tax')

  在代码中,我使用了mapped()函数处理了一个many2many字段tax_id。这个函数是odoo提供的,能够直接提取出某个字段的列表,或使用一个lambda表达式,对要获取的值进行加工处理。这个方法在实际开发中,是很常用的,主要用于2many字段。

  打开销售页面,self对应的是一个sale.order.line数据集,可以通过遍历的方式,获取每一个数据集,对每个数据集的数据进行处理。这在处理明细逻辑时要注意,很容易出现的错误是:

sale.order.line(1, 2)
/home/sam/odoo12/odoo/odoo/models.py(4692)ensure_one()
raise ValueError("Expected singleton: %s" % self)

  我只是在代码中增加了:

self.x_price_tax = 0

  报错的原因就是self是一个多订单行的数据集,对于数据集的处理要确保是单一对象。

  注意:如果你加了store=True,只会在第一次加载时进行计算,当第二次加载时就从数据库中直接查询了。

  下面是xml中的内容:

<record id="view_order_form_modify" model="ir.ui.view">
<field name="name">view.order.form.modify</field>
<field name="model">sale.order</field>
<field name="inherit_id" ref="sale.view_order_form"/>
<field name="arch" type="xml">
<!-- 增加``销售员``字段 -->
<xpath expr="//group/group/field[@name='partner_id']"
position="after"
>
<field name="x_salesman" />
</xpath>
<!-- 在订单行中,增加``税额``字段 -->
<xpath expr="//tree/field[@name='tax_id']"
position="after"
>
<field name="x_price_tax" />
</xpath>
</field>
</record>

  可能会有疑惑,为什么sale.order.line中的字段可以直接加在sale.order模型的视图中。我们来看一下源码:

<page string="Order Lines" name="order_lines">
<field name="order_line">
<tree string="Sales Order Lines">
<field name="tax_id" />
</tree>

  由于源码太多,我不得不对它进行删减,说明问题足够了,源码是开发过程中最好的老师

  在page标签内,有一个字段,该字段就是订单行order_line。

  能够看到tree标签是添加在order_line字段内部的,我们新增的字段是增加到tree标签内的。实际上,我们是在定义的sale.order.line的列表中增加了一个税额字段。因此,odoo并没有提示错误。

  如果,我们在销售员字段所在的视图中添加税额,则会报如下错误:

字段`x_price_tax`不存在
 <xpath expr="//group/group/field[@name='partner_id']" position="after">
<field name="x_salesman" />
<field name="x_price_tax" />
</xpath>

  添加成功后显示如下:

  

  在明细中添加字段的介绍,就介绍到这,下一篇我们来讨论下如何添加按钮。

odoo12 修行基础篇之 添加明细字段 (二)的更多相关文章

  1. odoo12 修行基础篇之 添加字段 (一)

    本人刚刚接触odoo12,大概有2个多月的时间,这两天有点时间,就集中写下博客. 本来是打算整理成笔记,想到这段时间的开发经历,着实感觉网上有关odoo的资料太少,学习资料也不多,既然与odoo有缘, ...

  2. cocos2dx基础篇(13) 编辑框之二CCEditBox

    [3.x] (1)去掉"CC" (2)设置虚拟键盘的编辑类型 > EditBoxInputMode 变为强枚举 EditBox::EditBoxInputMode // SI ...

  3. ESP8266开发之旅 基础篇④ ESP8266与EEPROM

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  4. ESP8266开发之旅 基础篇① 走进ESP8266的世界

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  5. ESP8266开发之旅 基础篇② 如何安装ESP8266的Arduino开发环境

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  6. ESP8266开发之旅 基础篇③ ESP8266与Arduino的开发说明

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  7. ESP8266开发之旅 基础篇⑥ Ticker——ESP8266定时库

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  8. Python基础篇【第7篇】: 面向对象(2)

    上一篇<初识面向对象>文章介绍了面向对象基本知识: 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使用(可以讲多函数中公 ...

  9. SQL Server调优系列基础篇(常用运算符总结——三种物理连接方式剖析)

    前言 上一篇我们介绍了如何查看查询计划,本篇将介绍在我们查看的查询计划时的分析技巧,以及几种我们常用的运算符优化技巧,同样侧重基础知识的掌握. 通过本篇可以了解我们平常所写的T-SQL语句,在SQL ...

随机推荐

  1. SpringBoot异常处理统一封装我来做-使用篇

    SpringBoot异常处理统一封装我来做-使用篇 简介 重复功能我来写.在 SpringBoot 项目里都有全局异常处理以及返回包装等,返回前端是带上succ.code.msg.data等字段.单个 ...

  2. Android原生PDF功能实现:PDF阅读、PDF页面跳转、PDF手势伸缩、PDF目录树、PDF预览缩略图

    1.背景 近期,公司希望实现安卓原生端的PDF功能,要求:高效.实用. 经过两天的调研.编码,实现了一个简单Demo,如上图所示. 关于安卓原生端的PDF功能实现,技术点还是很多的,为了咱们安卓开发的 ...

  3. 初始bat命令

    任务:manven打包的jar包以及相关的bat文件,要将其设置为开机自启动. bat :批处理文件,通过简单的命令行方式对windows进行操作. 简单的bat命令: 1echo 显示命令,@带着个 ...

  4. Dijkstra算法 笔记与思路整理

    该文章可能存在硬伤与不妥,不能作为教程阅读.(因为我真的鶸 Dij作为单源最短路算法,需要先确定一个起点.Dij的函数主体为维护每个节点的dis和vis两个变量.dis表示该点距离起点的最短路权值和, ...

  5. 《Effective Java》 读书笔记(八)避免使用Finalizer和Cleaner机制

    Finalizer和Cleaner并不等同于C++中的析构函数,是不确定多久会被调用的,甚至有时候可能不会被调用,因此除了作为一个安全网或者终止非关键的本地资源,不应该在Finalizer或Clean ...

  6. 学习笔记04IIS

    IIS机制:1.能监听端口,获取socket的客户端对象2.获取请求报文,将请求报文变成对象.3.处理请求报文,通过HttpApplication.ProcessRequest方法来处理HttpCon ...

  7. [考试反思]0910csp-s模拟测试42:追求

    显而易见的暴力骗分. T1想到了bitset但是发现MLE后弃了,部分分都没拿. T2想到正解贪心打暴力过不了大样例弃了. T3牛逼题暴力. 考场没什么大失误,还可以. 不要轻易放弃每一个思路,可能再 ...

  8. CSPS_108

    二逼出题人写错T1题面&&写伪T3std祭

  9. windows系统一台电脑先后添加多个git账号

    概述 电脑上已经配置了github的ssh连接.现在又有一个不同的git账户,也就是要在一台电脑上配置两个git账号. 下面记录一下我配置的方法. 一.取消git全局配置 之前配置github的时候, ...

  10. .net core Json字符串的序列化和反序列化通用类源码,并模拟了10万数据对比DataContractJsonSerializer和Newtonsoft性能

    我们在开发中Json传输数据日益普遍,有很多关于Json字符串的序列化和反序列化的文章大多都告诉你怎么用,但是却不会告诉你用什么更高效.因为有太多选择,人们往往会陷入选择难题. 相比.NET Fram ...