如何计算OpenERP中两个日期之间的差异?

时间:2014-03-18 08:02:59

标签: openerp

在我的自定义模块中,我无法计算两个日期之间的差异。

我的字段是

'date_s':fields.datetime('Start Date'),
'date_e':fields.datetime('End Date'),

我想在我的持续时间字段中自动计算差异:

 'Duration':fields.char('Duration'),

2 个答案:

答案 0 :(得分:0)

  1. 为此目的使用一个函数字段:https://doc.openerp.com/trunk/server/03_module_dev_02/#functional-fields,在插件中有一些很好的例子可以得到关于这类字段的线索。

  2. 再考虑使用日期或日期时间。如果你不需要时间,那就使用日期......

  3. 如有进一步的问题,请问: - )

    编辑:以这种方式尝试你的功能

    import openerp.tools as tools
    import datetime
    def _get_days(self, cr, uid, ids, field_name, args, context=None):
        res = {}
        for date in self.browse(cr, uid, ids, context=context):
            fmt = tools.DEFAULT_SERVER_DATETIME_FORMAT
            date_s = datetime.datetime.strptime(date.date_s, fmt)
            date_e = datetime.datetime.strptime(date.date_e, fmt)
            res[date.id] = (date_e-date_s).days or False
        return res
    

答案 1 :(得分:0)

这是我写的一个简单的功能。希望它会对你有所帮助。

def onchange_return_date(self, cr, uid, ids, issuedate, returndate):
 a=datetime.strptime(issuedate,"%Y-%m-%d")
 b=datetime.strptime(returndate,"%Y-%m-%d")
 timedelta = b - a
 diff=timedelta.days
 return {'value': {'days':diff}}