本人刚刚接触odoo12,大概有2个多月的时间,这两天有点时间,就集中写下博客。

  本来是打算整理成笔记,想到这段时间的开发经历,着实感觉网上有关odoo的资料太少,学习资料也不多,既然与odoo有缘,想系统的整理下这段时间的心得体会,与有缘人分享,也算是响应了IT行业的宗旨了。

  废话少说,展开正题:

  odoo基础教程,比如odoo12的:https://alanhou.org/odoo-12-development/

  这个系列教程对我影响很大,在此,对大神Alan Hou表示衷心感谢

  我主要是想通过简单的例子,对一些odoo开发中常用的技术进行说明:

  第一篇要说的是添加字段:这也是我接触odoo12最开始的工作。

  准备工作:

  运行odoo,安装销售、采购、联系人三个模块,用于演示添加字段。

在视图中添加字段:

  

  以上是原销售订单form页面,我想在``客户``字段下增加``销售员``字段(从联系人直接关联)(sale.order是有的,用于演示)。

# -*- coding:utf- -*-
"""销售模块扩展""" from odoo import fields, models # 销售模块扩展
class SaleOrderExtension(models.Model):
"""销售模块扩展"""
_inherit = 'sale.order'
# 销售员
x_salesman = fields.Many2one(
'res.users',
string='销售员',
related='partner_id.user_id'
)

  在models目录中创建sale_order_extension.py文件

  在models/__init__.py文件中引用该文件

  related可以通过当前类的某个关联字段,关联到该字段所关联模型中的其它字段。

  比如上述就是通过sale.order模型中的partner_id字段,关联到res.partner中的user_id字段

  注意的是:x_salesman的关联模型是res.users,与user_id的字段属性是一致的,否则会报如下错误:

/home/sam/odoo12/odoo/odoo/fields.py()convert_to_cache()
raise ValueError("Wrong value for %s: %r" % (self, value))

  就是因为我把res.users搞成了res.partner

x_salesman = fields.Many2one(
'res.partner',
string='销售员',
related='partner_id.user_id'
)

  还有可能遇到这样的错误:

TypeError: Model 'sale.order' does not exist in registry.

  这是由于在__manifest__.py文件中的'depends'中没有引入对应模块导致的:

'depends': ['base',],

  修改如下:

'depends': ['base', 'sale',],

  这个'sale'索引用的是目录名,因为添加字段所继承的sale.order模型就在sale目录下:

  / home / sam / odoo12 / odoo / addons / sale / models / sale.py

  在views目录中创建sale_order_extension.xml文件,代码如下:

<?xml version="1.0" encoding="UTF-8" ?>
<odoo> <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>
</field>
</record> </odoo>

  对于xml文件的修改,可能报如下错误:

元素 '<xpath expr="//group/div/field[@name='partner_id']">' 在母级视图中没有找到

  注意我把group修改成了div,这属于xpath写错了

  还有可能也报类似的问题,但是问题原因并不是xpath,而是继承的视图的外部ID不对

  如我把外部ID修改成如下,也会报类似错误:

<field name="inherit_id" ref="base.res_partner_kanban_view"/>
元素 '<xpath expr="//group/group/field[@name='partner_id']">' 在母级视图中没有找到

  关于找外部ID的方法,有几个技巧可以分享给大家:

  找form、tree、kanban等odoo自带类型,可以使用如下方式:

  开启开发者模式,点击右上角的debug图标

  选择下拉菜单中的相关项,具体可自己试验

  可以在弹出的页面中找到外部ID

  找按钮的外部ID,可以使用如下方式:

  打开谷歌浏览器:

  右键点击一个按钮,选择检查

  红框圈出的就是这个按钮对应的外部ID,这个在添加按钮权限时,非常好用。

  可以看看字段添加后的效果,不可编辑,如果在联系人中修改了销售员字段,在选择客户时会自动带出,并显示在页面中。

在列表中添加字段:

  在列表中添加字段:

  我想在Quotation Date后面增加创建人,使用系统默认字段create_uid,只添加xml就可以了

  在上述的xml文件中,补充如下代码:

<record id="view_order_tree_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_quotation_tree_with_onboarding"/>
<field name="arch" type="xml">
<!-- 增加``创建人``字段 -->
<xpath expr="//field[@name='date_order']"
position="after"
>
<field name="create_uid" />
</xpath>
</field>
</record>

  其它的odoo自带的添加字段的方式与上述相同

  需要注意的就是外部ID的引用,以及xpath的使用

  有时可能会遇到修改无效也不报错的情况,很有可能是文中有多个相同字段,你的xpath并没有选中你想要修改的字段。

  这在TAB页中和明细中添加字段时会经常遇到。

  上述的基本方法能够适用大部分的情况了,后一篇补充下在明细中添加计算字段的情况。

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

  1. odoo12 修行基础篇之 添加明细字段 (二)

    前一篇介绍了如何在视图和表单中添加字段.本节内容,我们讨论下如何在明细中加字段. 我想在销售页面明细中增加税额字段,这在表sale.order.line中已经存在,在此仅用来演示. odoo的明细一般 ...

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

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

  3. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  4. SQL Server调优系列基础篇(常用运算符总结)

    原文:SQL Server调优系列基础篇(常用运算符总结) 前言 上一篇我们介绍了如何查看查询计划,本篇将介绍在我们查看的查询计划时的分析技巧,以及几种我们常用的运算符优化技巧,同样侧重基础知识的掌握 ...

  5. DDD分层架构之领域实体(基础篇)

    DDD分层架构之领域实体(基础篇) 上一篇,我介绍了自己在DDD分层架构方面的一些感想,本文开始介绍领域层的实体,代码主要参考自<领域驱动设计C#2008实现>,另外参考了网上找到的一些示 ...

  6. 讲讲Linq to SQL映射(基础篇)

    讲讲Linq to SQL映射(基础篇) 这篇主要讲Linq to  SQL基于属性的映射.即映射数据库,映射表,映射列,映射关系,映射存储过程, 映射函数.然而创建这种映射有三种方法,他们分别是OR ...

  7. Python 经典面试题汇总之基础篇

    基础篇 1:为什么学习Python 公司建议使用Python,然后自己通过百度和向有学过Python的同学了解了Python.Python这门语言,入门比较简单,它简单易学,生态圈比较强大,涉及的地方 ...

  8. Java面试题之基础篇概览

    Java面试题之基础篇概览 1.一个“.java”源文件中是否可以包含多个类(不是内部类)?有什么限制? 可以有多个类,但只能有一个public的类,且public的类名必须与文件名相一致. 2.Ja ...

  9. 聊聊数据库~3.SQL基础篇

    上篇回顾:聊聊数据库~SQL环境篇 扩展:为用户添加新数据库的权限 PS:先使用root创建数据库,然后再授权grant all privileges on 数据库.* to 用户名@"%& ...

随机推荐

  1. 9i oracle数据库迁移到11G(exp)

    这个是之前生产上打算迁移的文档,后面离职了没有在停机迁移,但是测试过几次没有问题,其中需要把9I的110,120库迁移到11g一个数据库中,但是110,120库之间有相同的表名字,以及有DBLINK. ...

  2. MySQL操作(一)用户及权限

    一.mysql 里的所有用户都是存储在数据库mysql的user表里 二.创建普通用户.赋权.撤销权限 的操作 1.创建用户(需要先用root进去mysql)格式:create  user  '用户名 ...

  3. Java多线程编程(四)Lock的使用

    一.使用ReentrantLock类 在Java多线程中,可以使用synchronized关键字来实现线程之间的同步互斥,但ReentrantLock类也能达到同样的效果,并且在扩展功能上也更加强大, ...

  4. 使用IDEA开发Spark程序

    一.分布式估算圆周率 1.计算原理 假设正方形的面积S等于x²,而正方形的内切圆的面积C等于Pi×(x/2)²,因此圆面积与正方形面积之比C/S就为Pi/4,于是就有Pi=4×C/S. 可以利用计算机 ...

  5. fenby C语言 P9

    逻辑运算 真1 假0 &&与 真&&真为真 真&&假为假 假&&真为假 假&&假为假 ||或 真||真为真 真||假为真 ...

  6. Python基础-语法知识

    ——编程语言的发展史 机器语言 优点:执行速度够快 缺点:开发效率非常低 汇编语言 优点:执行效率相较于机器语言略低 缺点:开发效率相较于机器语言略高 高级语言 C.C++.C#.java.PHP.p ...

  7. 学习笔记23_AspMVC项目

    *创建AspMVC项目 (1)会自动创建App_Data文件夹,是用户不能访问和下载的.一般用户能访问那些文件夹,可以在IIS中配置. (2)App_Start文件夹,用于放置与程序有关的配置文件. ...

  8. [考试反思]1105csp-s模拟测试102: 贪婪

    还是有点蠢... 多测没清空T3挂40...(只得了人口普查分20) 多测题要把样例复制粘两遍自测一下防止未清空出锅. 然而不算分... 其实到现在了算不算也不重要了吧... 而且其实T3只考虑最长路 ...

  9. CSPS模拟 61

    T1 模拟 T2 ?? T3 哈希

  10. zookeeper能干啥

    在Zookeeper的官网上有这么一句话:ZooKeeper is a centralized service for maintaining configuration information, n ...