在odoo 9.0中连接日期和时间

时间:2016-05-18 06:26:33

标签: python-2.7 odoo-8 openerp-7 odoo-9

我有两个字段,如下所示。

>  appo_date = fields.Date(string="Appointment Date")
>  appo_time = fields.Float(string="Appointment Time")

我需要连接这两个字段。为此我写了一个函数,如下所示。

def _combine(self, cr, uid, ids, field_name, args, context=None):
        values = {}
        for id in ids:
            rec = self.browse(cr, uid, [id], context=context)[0]
            values[id] = {}
            values[id] = '%f - %f' % (rec.appo_date, rec.appo_time)
        return values

并在单独的字段中调用该函数,如下所示。

appo_date_and_time = fields.Char(compute='_combine', string='Appointment Date/Time', arg=('appo_date','appo_time'), method=True)

这些字段在xml文件中调用

<field name="appo_date"/>
<field name="appo_time"/>
<field name="appo_date_and_time"/>

我收到错误

TypeError: _combine() takes at least 6 arguments (5 given)

1 个答案:

答案 0 :(得分:1)

您正在使用Odoo 9.因此建议您使用新的api进行练习。

尝试使用此代码:

@api.multi
def _combine(self):
    if self.appo_date and self.appo_time:
        self.appo_date_and_time = '%f - %f' % (self.appo_date, self.appo_time)
    elif self.appo_date:
        self.appo_date_and_time = str(self.appo_date)
    elif self.appo_time:
        self.appo_date_and_time = str(self.appo_time)
    else
        self.appo_date_and_time = 'No Date and Time set'