说明:

  单据自动编码允许定义 单据前缀+按当前年、月、日、时、分、秒+流水号+单据后缀
  单据自动编号允许按所有公司统一编号或按分公司单独编号
  单据自动编号中的流水号部分未按月重新编号,不断累计,当超出定义长度时,自动进位增加位数
  暂时未实现按月重新编号,需要每月手工在设置中改变下一编号(客户肯定不会同意这样做的,待解决)

示例代码 xml 部分,编码规则定义:
sale_sequence.xml

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data noupdate="1">
        <!-- Sequences for dispatch.sale --> 
        <record id="seq_type_dispatch_sale" model="ir.sequence.type">
            <field name="name">Dispatch Sale</field>
            <field name="code">dispatch.sale</field>
        </record>
        <record id="seq_dispatch_sale" model="ir.sequence">
            <field name="name">Dispatch Sale</field>
            <field name="code">dispatch.sale</field>
            <field name="prefix">po-%(y)s%(month)s-</field>
            <field name="padding">4</field>
            <field name="company_id" eval="False"/>
        </record>
    </data>
</openerp>

 示例代码 python 部分:

_columns={
       
'name':fields.char(u'单号', size=64, select=True, required=True,
readonly=True),
       
'date':fields.date(u'日期', select=True, required=True,
readonly=True),
       
'month':fields.function(_get_month, method=True, type='char', size=10, string =
u'月份', store=True,
invisible=True),
       
"customer":fields.many2one("dispatch.customer","客户", select=True, required=True,
readonly=True,
states={'draft':[('readonly',False)]}),
       
"product":fields.many2one("dispatch.product","产品", select=True, required=True,
readonly=True,
states={'draft':[('readonly',False)]}),
       
'price':fields.float(u'单价', digits=(18, 2), required=True, readonly=True,
states={'draft':[('readonly',False)]}),
       
'num':fields.integer(u'数量', required=True, readonly=True,
states={'draft':[('readonly',False)]}),
       
'cost':fields.float(u'成本', digits=(18, 2), required=True,
invisible=False),
       
'cost_view':fields.function(_view_cost, method=True, type='float', digits=(18,
2), string = u'成本',
invisible=True),
       
'sum_sale':fields.function(_sum_sale, method=True, type='float', digits=(18, 2),
string = u'销售金额', store=True),
       
'sum_cost':fields.function(_sum_cost, method=True, type='float', digits=(18, 2),
string = u'成本金额', store=True),
       
'sum_profit':fields.function(_sum_profit, method=True, type='float', digits=(18,
2), string = u'利润金额', store=True),
       
'employee_id':fields.many2one('hr.employee',u'业务员', select=True, required=True,
readonly=True,
states={'draft':[('readonly',False)]}),
       
'department_id':fields.many2one('hr.department',u'部门', select=True,
required=True, readonly=True,
states={'draft':[('readonly',False)]}),
       
'klbh':fields.char(u'开龙单号',size=64,required=False, readonly=True,
states={'draft':[('readonly',False)]}),
       
"work_order":fields.many2one("dispatch.work_order","服务单", required=False,
readonly=True,
states={'draft':[('readonly',False)]}),
       
'note':fields.text(u'备注', readonly=True,
states={'draft':[('readonly',False)]}),
       
'state': fields.selection([('draft', u'草稿'),('confirmed', u'已确认')], u'状态',
select=True, readonly=True),
       
'create_uid': fields.many2one('res.users', u"创建用户", select=True,
invisible=False, readonly=True),
#需要在记录中读取该字段或者在视图中显示该字段时,对象中必须包含
    }
   
_defaults={
        'name': lambda
obj, cr, uid, context:
'/',
       
'date':fields.date.context_today,
       
#'employee_id':_employee_get,
       
'state':'draft'
    }
   

    #数据库约束
    _sql_constraints =
[
        ('name_check',
"unique(name)",
u"单据编号已经存在且不允许重复."),
       
('num_check', "CHECK (num <> 0 )", u"销售数量不能等于 0 ."),
   
]
   
    def create(self, cr, uid, vals,
context=None):
        if
vals.get('name','/')=='/':
           
vals['name'] = self.pool.get('ir.sequence').get(cr, uid, 'dispatch.sale') or
'/'
        return
super(dispatch_sale, self).create(cr, uid, vals, context=context)

openerp学习笔记 单据自动编号(编码规则)的更多相关文章

  1. 转:从开源项目学习 C 语言基本的编码规则

    从开源项目学习 C 语言基本的编码规则 每个项目都有自己的风格指南:一组有关怎样为那个项目编码约定.一些经理选择基本的编码规则,另一些经理则更偏好非常高级的规则,对许多项目而言则没有特定的编码规则,项 ...

  2. thinkphp学习笔记9—自动加载

    原文:thinkphp学习笔记9-自动加载 1.命名空间自动加载 在3.2版本中不需要手动加载类库文件,可以很方便的完成自动加载. 系统可以根据类的命名空间自动定位到类库文件,例如定义了一个类Org\ ...

  3. openerp学习笔记 模块结构分析

    以OpenERP7.0中的 hr_expense 模块为例: 如图中代码所示: __init__.py :和普通 Python 模块中的__init__.py 作用相同,主要用于引用模块根目录下的.p ...

  4. openerp学习笔记 跟踪状态,记录日志,发送消息

    跟踪状态基础数据: kl_qingjd/kl_qingjd_data.xml <?xml version="1.0"?><openerp>    <d ...

  5. 【JAVAEE学习笔记】hibernate02:实体规则、对象状态、缓存、事务、批量查询和实现客户列表显示

    一.hibernate中的实体规则 实体类创建的注意事项 1.持久化类提供无参数构造 2.成员变量私有,提供共有get/set方法访问.需提供属性 3.持久化类中的属性,应尽量使用包装类型 4.持久化 ...

  6. openerp学习笔记 domain 的应用

    1.在Action中定义,domain用于对象默认的搜索条件: 示例: <record id="action_orders" model="ir.actions.a ...

  7. Hibernate学习笔记(二)—— 实体规则&对象的状态&一级缓存

    一.持久化类 1.1 什么是持久化类? Hibernate是持久层的ORM映射框架,专注于数据的持久化工作.所谓的持久化,就是将内存中的数据永久存储到关系型数据库中.那么知道了什么是持久化,什么又是持 ...

  8. jade 学习笔记 - gulp 自动编译

    实时监控   jade -P -w .\test1.jade sublime 分栏,可以看到实时修改情况     1. 元素写法 doctype html <!--[if IE8]>< ...

  9. Spring 4.0.2 学习笔记(2) - 自动注入及properties文件的使用

    接上一篇继续, 学习了基本的注入使用后,可能有人会跟我一样觉得有点不爽,Programmer的每个Field,至少要有一个setter,这样spring配置文件中才能用<property> ...

随机推荐

  1. 解决 /etc/init.d/php-fpm no such file or directory等相关问题

    vi /etc/init.d/php-fpm #! /bin/sh # Comments to support chkconfig on CentOS # chkconfig: 2345 65 37 ...

  2. shell脚本中的EOF以及文件重定向

    <<EOF  (内容)  EOF  可以把EOF替换成其他东西(分解符)  意思是把内容当作标准输入传给程序 这里再简要回顾一下<<的用法.当Shell看到<<的时 ...

  3. Java入门 异常处理

    Java入门 异常处理 1.处理异常(try-catch以及try-catch-finally): a)try会抛出很多种类型的异常-多重catch块的处理 eg:try{ //一些会抛出异常的方法 ...

  4. Hadoop_08_客户端向HDFS读写(上传)数据流程

    1.HDFS的工作机制: HDFS集群分为两大角色:NameNode.DataNode (Secondary Namenode) NameNode负责管理整个文件系统的元数据 DataNode 负责管 ...

  5. 1.Lucene简介

    1.Lucene简介 Lucene是一个基于Java的全文信息检索工具包,它不是一个完整的搜索应用程序,而是为你的应用程序提供索引和搜索功能 Lucene是开源项目,它是可扩展,高性能的库用于索引和搜 ...

  6. JVM锁说明

          以前Synchronised关键字加锁效率问题,经常受到吐槽.后来java的开发团队进行了优化,引入了偏向锁.自旋锁.轻量锁,性能有了很大的提升.下面我们来分析下这里面的过程和原理.   ...

  7. 无法连接Web 的 IIE 问题

    我一个解决方案里有两个项目在一块,其中一个就突然凉凉了 然后在网上找了很多,基本都是删除vs文件,在启动,幸运的是,并没什么用. 最后我用了这个: 打开Visual Studio, 右键单击网站 &g ...

  8. Task底层实现原理探秘

    .NET 4包含新名称空间System.Threading.Tasks,它 包含的类抽象出了线程功能, 在底层使用ThreadPool. 任务表示应完成的某个单元的工作. 这个单元的工作可以在单独的线 ...

  9. ajax给增删修加入非空

    <span>标签加入 <script type="text/javascript"> $(".inp2").click(function ...

  10. PyHook3----键盘鼠标操作

    需要安装 pywin32 安装pyHook 下载网址:https://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml 注意选择的pyHook版本一定要和python对 ...