我需要在特定字段中加载序列号。
为此,我正在使用该ir.sequence
模型,正如我在其他模块中看到的那样。
问题是,它还没有工作,我不知道我在这里做错了什么,也许我正在使用的示例只适用于“标题”字段?
这是我的代码:
... _name = "product.product"
_description = "Product"
_table = "product_product"
_inherits = {'product.template': 'product_tmpl_id'}
_inherit = ['mail.thread']
_order = 'default_code,name_template'
_columns = {
'codigo_n' : fields.char('Codigo Arancelario', size=64),
'tec_esp' : fields.char('Especificaciones tecnicas', size=72),
'qty_available': fields.function(_product_qty_available, type='float', string='Quantity On Hand'),
'virtual_available': fields.function(_product_virtual_available, type='float', string='Quantity Available'),
'incoming_qty': fields.function(_product_incoming_qty, type='float', string='Incoming'),
'outgoing_qty': fields.function(_product_outgoing_qty, type='float', string='Outgoing'), ... code keeps going...
这里有趣的字段是codigo_n
类型,char
我添加了如下_defaults
语句来使用ir.sequence
它:
_defaults = {
'codigo_n': lambda obj, cr, uid, context: obj.pool.get('ir.sequence').get(cr, uid,'product.product'),
}
显然我创建了 .xml 序列文件,添加到文件中的data
依赖__openerp__.py
项,这是代码custom_sequence.xml
:
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data noupdate="1">
<!-- Secuencias para product.product -->
<record id="seq_type_product_product" model="ir.sequence.type">
<field name="name">Product</field>
<field name="code">product.product</field>
</record>
<record id="seq_product_product" model="ir.sequence">
<field name="name">Product</field>
<field name="code">product.product</field>
<field name="prefix">NG</field>
<field name="padding">5</field>
<field name="company_id" eval="False"/>
</record>
</data>
</openerp>
我认为这是设置它的正确方法,我只需要codigo_n
使用这个序列,任何关于它为什么不起作用的想法?
我希望我已经解释了自己。
提前致谢。