将产品数量与库存相关联 - 自定义模块 - OpenErp

时间:2013-04-12 04:11:45

标签: python module openerp product

我有一个使用物品,产品,货币,uom等的模块。

我需要当我询问请购单或在openerp数据库中购买产品时,它会自动从系统数据库中排出数量。

我在'product.product'中看到有一些名为

的函数/字段
_product_qty_available
_product_virtual_available
_product_outgoing_qty
_product_incoming_qty

我是否应该继承这些功能来管理我的模块中的产品,并在系统中更新它们,如请购单或采购订单?

我的module.py

的代码
import time
from datetime import datetime
from osv import osv, fields
from openerp.tools import DEFAULT_SERVER_DATE_FORMAT, DEFAULT_SERVER_DATETIME_FORMAT, DATETIME_FORMATS_MAP
import openerp.addons.decimal_precision as dp
from openerp.tools.translate import _

class certificados(osv.osv):

_name = 'certificados.certificados'
_description="Certificados de No Produccion"

_columns = {
            'Registro_Numero' : fields.integer('Registro Numero'),
            'Fecha_de_Emision': fields.date('Fecha de Emision', required=True, select=True),
            'Fecha_de_Solicitud': fields.date('Fecha de Solicitud', required=True, select=True),
            'Fecha_del_Documento': fields.date('Fecha del Documento', required=True, select=True),
            'Vigencia' : fields.integer('Vigencia'), 'cert_ids' : fields.one2many('certificados.line','requisicion_id','Items del Certificado'),
            'descripcion' : fields.text('Descripcion'),
            'notas' : fields.text('Notas'),
            }


class certificados_line(osv.osv):

_name = "certificados.line"
_description="Certificados No Produccion"
_inherit = ['mail.thread', 'ir.needaction_mixin']

_columns = {
    'Item' : fields.integer('Item'),
    'Codigo_Arancelario' : fields.integer('Codigo Arancelario'),
    'product_id' : fields.many2one('product.product', 'Material'),
    'Descripcion_Arancelaria' : fields.char('Descripcion Arancelaria', size=42, required = True, translate = True), 
    'Especificaciones_Tecnicas' : fields.char('Especificaciones Tecnicas', size=60, required = True, translate = True), 
    'Cantidad' : fields.float('Cantidad'), 'Unidad_de_Medida': fields.many2one('product.uom', 'Unidad de Medida'),
    'Precio_Unitario_Declarado' : fields.float('Precio Unitario Declarado'), 'Moneda' : fields.many2one('res.currency', 'Moneda'),
    'Valor_En_Divisas' : fields.float('Valor En Divisas'),
    'requisicion_id' : fields.many2one('certificados.certificados', 'Certificados de No Produccion', ondelete='cascade'),
    'Cantidad_Consumida' : fields.float('Cantidad Consumida'), 'Cantidad_Disponible' : fields.float('Cantidad Disponible'),

}
certificados_line()

我希望我先解释一下自己,谢谢。

1 个答案:

答案 0 :(得分:0)

如果要在模块中使用product_id,只需通过many2one继承它即可。该产品的库存将由OpenERP自动维护。如果您将其出售,该产品的库存将减少,如果您将购买它,该产品的库存将增加。您还可以根据需要设置该产品的初始库存。