def create(self,cr,uid,vals,context=None):
if context is None:
context ={}
print 111111
print vals
[]
if vals.get('lx_origin', '/') == '/' :
vals['lx_origin'] = self.pool.get('ir.sequence').get(cr, uid, 'demo.contract.lx', context=context) or '/'
if vals['lx_origin'] and vals['lx_type']=='3':
vals['lx_origin']=vals['lx_origin']+'S' elif vals['lx_origin'] and vals['lx_type']=='4' :
vals['lx_origin']=vals['lx_origin']+'S(LX)' elif vals['lx_origin'] and vals['lx_type']=='5' :
vals['lx_origin']=vals['lx_origin']+'C' elif vals['lx_origin'] and vals['lx_type']=='6' :
vals['lx_origin']=vals['lx_origin']+'C(LX)'
else:
vals['lx_origin']=vals['lx_origin'] if vals['lx_origin'] and vals['display_name']==14:
vals['lx_origin']='HL'+vals['lx_origin'] elif vals['lx_origin'] and vals['display_name']==19:
vals['lx_origin']='TZRL'+vals['lx_origin'] elif vals['lx_origin'] and vals['display_name']==18:
vals['lx_origin']='JT'+vals['lx_origin'] elif vals['lx_origin'] and vals['display_name']==17:
vals['lx_origin']='YC'+vals['lx_origin'] elif vals['lx_origin'] and vals['display_name']==22:
vals['lx_origin']='XN'+vals['lx_origin'] elif vals['lx_origin'] and vals['display_name']==3 or vals['display_name']==13 or vals['display_name']==11:
vals['lx_origin']='WQ'+vals['lx_origin'] else:
vals['lx_origin']=vals['lx_origin'] new_id=super(demo_contract_lx,self).create(cr,uid,vals,context=context)
return new_id   WQLX2017-070S(LX)
def create(self, cr, uid, vals, context=None):
if context is None:
context = {}
if vals.get('name', '/') == '/':
vals['name'] = self.pool.get('ir.sequence').get(cr, uid, 'mrp.production.report') or '/'
ctx = dict(context or {}, mail_create_nolog=True)
new_id = super(mrp_production_report, self).create(cr, uid, vals, context=ctx)
bgdate=vals.get('date')
name=vals.get('name')
sql="update mrp_production_report_line set ldate='%s',lrname='%s' where line_id=%d"%(bgdate,name,new_id)
cr.execute(sql)
return new_id
  第三种:  TZRL2017-001SL 
# 新加的地方
def create(self, cr, uid, vals, context=None):
context = context or {} partner_id = vals.get('display_name')
print partner_id # 根据公司来生成不同的编号
if partner_id:
vals['lx_origin'] = self.get_lx_sequence(cr,uid,partner_id)
else:
raise osv.except_osv(u'请先选择公司!') new_id=super(demo_contract_lx, self).create(cr, uid, vals, context)
return new_id def create_new_sequence(self,cr,uid,code,partner_id):
#创建编码原则
ir_sequence_type_obj=self.pool.get('ir.sequence.type')
ir_sequence_type_obj.create(cr,uid,{'name':code,'code':code})
values={}
values['name']=code
values['code']=code
values['implementation']='no_gap'
values['active']=True
values['prefix']="%(year)s-"
values['number_next']=1
values['number_next_actual']=1
values['number_increment']=1
values['padding']=3
ir_sequence_obj=self.pool.get('ir.sequence')
ir_sequence_obj.create(cr,uid,values) def get_lx_sequence(self,cr,uid,partner_id,context=None): code="demo_contract_lx_no_%d" %(partner_id) no=self.pool.get('ir.sequence').get(cr, uid, code, context=context) if no==False:
self.create_new_sequence(cr,uid,code,partner_id)
no=self.pool.get('ir.sequence').get(cr, uid, code, context=context)
partner_ids=self.pool.get('res.partner').search(cr,uid,[('id','=',partner_id)])
partner_obj=self.pool.get('res.partner').browse(cr,uid,partner_ids)
no = "%s%s" %(partner_obj.code,no)
return no

所用方法:
def get(self, cr, uid, code, context=None):
company_ids = self.pool.get('res.company').search(cr, uid, [], context=context) + [False] ids = self.search(cr, uid, ['&', ('code', '=', code), ('company_id', 'in', company_ids),('active','=',True)]) # assert len(ids)==1
ir_seq_obj=self.browse(cr,uid,ids,context)
implementation=ir_seq_obj.implementation if implementation=='yyrnum': #表示编号用年月日+流水号 那么只输入前缀和后缀即可
oldnyr=ir_seq_obj.nyr #现在模块在使用的年月日
nowyyr=datetime.datetime.now().strftime("%Y%m%d") #当前年月日
prefix=ir_seq_obj.prefix if ir_seq_obj.prefix else ''
suffix=ir_seq_obj.suffix if ir_seq_obj.suffix else ''
padding=ir_seq_obj.padding if oldnyr==nowyyr: #如果序列规则保存的日期和当前的是一样,那么说明是同一天,反之不是同一天,那么就修改保存的日期以及序列从1开始
yyrnext_num=ir_seq_obj.yyrnext_num #序列号
#修改下一个号码
self.write(cr,uid,ids,{'yyrnext_num':yyrnext_num+1})
else:
yyrnext_num=1
self.write(cr,uid,ids,{'nyr':nowyyr,'yyrnext_num':2}) return prefix+nowyyr+'%%0%sd' % padding % yyrnext_num+suffix
else:
return self.get_id(cr, uid, code, 'code', context)

odoo创建编号的更多相关文章

  1. Odoo创建基础模块和相关内容

    Odoo创建模块 这里我先引用一下几篇文章,这里完整的实现了一个odoo的模块创建demo https://segmentfault.com/a/1190000014047552 https://se ...

  2. 记一次odoo创建新的模块时,但是在odoo web界面找不到应用的案例

    原因就是在odoo.conf配置文件中没有说明  模块查找的路径

  3. Odoo创建数据库时出现的问题 DataError: new encoding (UTF8) is incompatible with the encoding of the template database (SQL_ASCII)

    解决方案: 执行如下指令进入PostgreSQL控制台: sudo -u postgres psql postgres 然后在PostgreSQL控制下按顺序执行如下指令: update pg_dat ...

  4. Java 在Word中创建多级项目符号列表和编号列表

    本文分享通过Java程序代码在Word中创建多级项目符号列表和编号列表的方法.程序运行环境如下: IntelliJ IDEA 2018(JDK 1.8.0) Word 2013 Word Jar包:F ...

  5. odoo视图入门学习- tree视图的使用

    上一篇内容:如何快速在odoo中创建自己的菜单 前言 上面的内容我们已经学会了如何去创建odoo的菜单,下面我们要学习的是odoo的基础视图tree视图,我们的目标是实现型号管理的列表页面 创建mod ...

  6. Odoo 10的Linux安装

    CentOS7安装Odoo10流程如下一.更新系统#yum clean all#yum update 二.安装 PostgreSQL 1.安装数据库#yum install postgresql po ...

  7. 《Odoo开发指南》精选分享—第1章-开始使用Odoo开发(1)

    引言 在进入Odoo开发之前,我们需要建立我们的开发环境,并学习它的基本管理任务. 在本章中,我们将学习如何设置工作环境,在这里我们将构建我们的Odoo应用程序.我们将学习如何设置Debian或Ubu ...

  8. 2.Odoo产品分析 (一) – 一切为零

    查看Odoo产品分析系列--目录 1. 默认数据库 声明在先  本系列文档(Odoo产品分析)整理来自本人对该ERP的理解,并结合文档Working-with-Odoo-10-Second-Editi ...

  9. macOS Sierra 10.12.6 odoo 10.0 开发环境配置

    参考了网上的一些教程,将最终过程记录一下,其中需要的一些程序,我已经放到百度网盘: https://pan.baidu.com/s/1boKHSTL 1.抹盘安装macOS Sierra 10.12. ...

随机推荐

  1. BZOJ3351: [ioi2009]Regions(根号分治)

    题意 题目链接 Sol 很神仙的题 我们考虑询问(a, b)(a是b的祖先),直接对b根号分治 如果b的出现次数\(< \sqrt{n}\),我们可以直接对每个b记录下与它有关的询问,这样每个询 ...

  2. Win7/8/10十个最强大通用快捷键

    Windows 操作系统功能丰富,可视化的界面能够帮助我们提高工作效率.不过,日常使用中,很多用户都习惯“一只鼠标走天下”,频繁的点击让手指疲惫不堪. 为此,我们总结了十个适用于 Windows 7 ...

  3. jQuery事件和JSON点语法

    <head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" ...

  4. AsyncTask GET请求

    布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android= ...

  5. 《Inside C#》笔记(一) .NET平台

    C# 基于.NET运行时,所以有必要首先对.NET以及C#与.NET平台的关系有一定的了解. 一 .NET平台 .NET背后的基本思想是将原本独立工作的设备.网络服务整合在一个统一的平台上,从而可以为 ...

  6. Android Design Support Library(二)用NavigationView实现抽屉菜单界面

    NavigationView在MD设计中非常重要,之前Google也提出了使用DrawerLayout来实现导航抽屉.这次,在Android Design Support Library中,Googl ...

  7. ElementUI制作树形表组件

    提要 最近项目中需要用到树形表格来描述部门.区域之间的父子展开关系.但是已经在项目中使用的Vue的成熟组件ElementUI以及iViewUI组件都没有提供相应的树形表格组件,无奈找了其他替代方案也都 ...

  8. Python之Pandas知识点

    很多人都分不清Numpy,Scipy,pandas三个库的区别. 在这里简单分别一下: NumPy:数学计算库,以矩阵为基础的数学计算模块,包括基本的四则运行,方程式以及其他方面的计算什么的,纯数学: ...

  9. 从零自学Java-4.使用字符串来交流

    1.使用字符串来存储文本: 2.在程序中显示字符串: 3.在字符串中包含特殊的字符: 4.拼接字符串: 5.在字符串中包含变量: 6.比较字符串: 7.判断字符串的长度: 程序Credits:显示一部 ...

  10. python函数-匿名函数

    1,匿名函数,故名思意,就是没有名字的函数. def fun(x): return x+x 上述代码的作用就是求x+x的和的函数.如果调用该函数的话,可以使用fun(1)即可.那么lambda函数和上 ...