我注意到一件奇怪的事。我正在创建计算方法,我需要使用create_date
字段,但是当我尝试strptime
时,我收到错误,我使用bool
字段,我需要使用字符串。当我从方法打印它时,它输出为False
。但是当我进入数据库并编写sql查询以获取create_date时,它显示了正常的日期时间。
更有趣的是,如果我在视图中定义create_date
,那么create_date
会变成str
类型,我可以在调用print时看到日期时间。有谁知道它的意图是这样的(以及为什么)或它是某种错误?
产生这些结果的代码:
from openerp import models, fields
from openerp.api import one, depends
class crm_lead(models.Model):
_inherit = 'crm.lead'
stage_deadline = fields.Datetime('Stage Deadline', compute="_compute_stage_deadline")
@one
@depends('section_id.stage_config_ids', 'stage_id', 'create_date')
def _compute_stage_deadline(self):
print type(self.create_date) #prints 'bool' if this field is not defined in view. Prints 'str'
self.stage_deadline = datetime.now()
如果我添加此视图:
<?xml version="1.0"?>
<openerp>
<data>
<!-- CRM Lead Form View -->
<record model="ir.ui.view" id="crm_case_form_view_leads_inherit">
<field name="name">CRM - Leads Form - Inherit</field>
<field name="model">crm.lead</field>
<field name="inherit_id" ref="crm.crm_case_form_view_leads"/>
<field name="arch" type="xml">
<field name="priority" position="after">
<field name="create_date" invisible="1"/>
</field>
</field>
</record>
</data>
</openerp>
然后create_date
变为str
类型。如果我删除此视图,则会返回bool
类型。所以这种方式我不能使用create_date,如果它没有在视图中定义。
答案 0 :(得分:1)
它似乎与未满足的依赖关系有关。未使用的前两个依赖项('section_id.stage_config_ids', 'stage_id'
)由于某种原因它也将create_date
评估为False
。当我删除这些依赖项时,它已得到修复。
我唯一不理解的是为什么将视图转换后的字段中的字段包含回str
,即使依赖项是错误的?
答案 1 :(得分:1)
如果视图中存在日期字段,但在保存时未填充(空),则在计算方法中使用该日期时,功能字段将变为空白字符串, 如果在视图中根本没有声明日期字段,它将评估为False。