根据条件获取其他模型字段的总和
Get sum of other model field base on condition
如果 ru.students
的名称字段等于 student_id
ru.invoice
。
我使用了browse
方法,但它不起作用。
class ru_students(models.Model):
_name = 'ru.students'
_rec_name = 'code'
def _get_total(self, cr, uid, ids, context=None):
pool_re = self.pool.get('ru.invoice')
pool_rec = pool_re.browse(cr, uid, ids, [('name','=','student_id')],
context=context)
for field in self:
for line in pool_rec:
x = 0.0
x += line.total
field.payed += x
name = fields.Char(string="Name")
payed = fields.Float(compute="_get_total")
class ru_invoice(models.Model):
_name = 'ru.invoice'
_rec_name = 'code'
@api.multi
@api.depends('qty','unit_price')
def get_total(self):
for rec in self:
x = 0.0
x = rec.qty * rec.unit_price
rec.total = x
student_id = fields.Many2one('ru.students','Student ID")
qty = fields.Float(string="Quantity")
unit_price = fields.Float(string="Unit Price")
total = fields.Float(compute="_get_totals",string="Total")
首先,注意不要将 API7 代码与 API8 代码混合使用,如果可以,请始终使用 API8 代码(此外,使用 API8 会更容易)。我想你想在你的字段 payed
上使用这个(也检查 class ru_invoice
因为我在那里更正了一些东西 - 示例:在 total
字段中你有当您想调用 _get_total
-).
时,在 compute
中写入 _get_totals
class ru_students(models.Model):
_name = 'ru.students'
_rec_name = 'code'
@api.multi
@api.depends('invoices')
def _get_total(self):
for student in self:
student.payed = sum(
invoice.total for invoice in student.invoices)
name = fields.Char(string='Name')
payed = fields.Float(compute='_get_total', string='Payed')
invoices = fields.One2many(comodel_name='ru.invoice',
inverse_name='student_id',
string='Invoices of the student')
class ru_invoice(models.Model):
_name = 'ru.invoice'
_rec_name = 'code'
@api.multi
@api.depends('qty', 'unit_price')
def _get_total(self):
for invoice in self:
invoice.total = invoice.qty * invoice.unit_price
student_id = fields.Many2one(comodel_name='ru.students',
string='Student ID')
qty = fields.Float(string='Quantity')
unit_price = fields.Float(string='Unit Price')
total = fields.Float(compute='_get_total', string='Total')
如果 ru.students
的名称字段等于 student_id
ru.invoice
。
我使用了browse
方法,但它不起作用。
class ru_students(models.Model):
_name = 'ru.students'
_rec_name = 'code'
def _get_total(self, cr, uid, ids, context=None):
pool_re = self.pool.get('ru.invoice')
pool_rec = pool_re.browse(cr, uid, ids, [('name','=','student_id')],
context=context)
for field in self:
for line in pool_rec:
x = 0.0
x += line.total
field.payed += x
name = fields.Char(string="Name")
payed = fields.Float(compute="_get_total")
class ru_invoice(models.Model):
_name = 'ru.invoice'
_rec_name = 'code'
@api.multi
@api.depends('qty','unit_price')
def get_total(self):
for rec in self:
x = 0.0
x = rec.qty * rec.unit_price
rec.total = x
student_id = fields.Many2one('ru.students','Student ID")
qty = fields.Float(string="Quantity")
unit_price = fields.Float(string="Unit Price")
total = fields.Float(compute="_get_totals",string="Total")
首先,注意不要将 API7 代码与 API8 代码混合使用,如果可以,请始终使用 API8 代码(此外,使用 API8 会更容易)。我想你想在你的字段 payed
上使用这个(也检查 class ru_invoice
因为我在那里更正了一些东西 - 示例:在 total
字段中你有当您想调用 _get_total
-).
compute
中写入 _get_totals
class ru_students(models.Model):
_name = 'ru.students'
_rec_name = 'code'
@api.multi
@api.depends('invoices')
def _get_total(self):
for student in self:
student.payed = sum(
invoice.total for invoice in student.invoices)
name = fields.Char(string='Name')
payed = fields.Float(compute='_get_total', string='Payed')
invoices = fields.One2many(comodel_name='ru.invoice',
inverse_name='student_id',
string='Invoices of the student')
class ru_invoice(models.Model):
_name = 'ru.invoice'
_rec_name = 'code'
@api.multi
@api.depends('qty', 'unit_price')
def _get_total(self):
for invoice in self:
invoice.total = invoice.qty * invoice.unit_price
student_id = fields.Many2one(comodel_name='ru.students',
string='Student ID')
qty = fields.Float(string='Quantity')
unit_price = fields.Float(string='Unit Price')
total = fields.Float(compute='_get_total', string='Total')