OpenERP 在报表的创作中始终有一个麻烦,那就是在报表中通过对象导航的方式获取的 selection 字段只能获取到该字段的 key 而不能获取对应的用户友好的描述文本。
举个具体的例子:销售单的 state 字段,在报表中使用 [[ object.state ]] 引用时,系统返回的将是 'draft', 'manual', 'confirmed' 等内部使用的 key,而不是对应的“草稿”、“手工”和“已确认”。由于报表是供业务人员打印及浏览,所以出现系统内部代码是完全不可接受的。
此问题 OpenERP SA 公司官方并没有提供理想的解决方案,许多系统内置的报表就直接显示了 selection 字段内部的 key。但是多亏了伟大的社区,aeroo_report 模块提供了一段非常好用的代码:
def _get_selection_items(self, kind='items'): def get_selection_item(obj, field, value=None): try: if isinstance(obj, report_sxw.browse_record_list): obj = obj[0] if isinstance(obj, (str,unicode)): model = obj field_val = value else: model = obj._table_name field_val = getattr(obj, field) if kind=='item': if field_val: return dict(self.pool.get(model) \ .fields_get(self.cr, self.uid, allfields=[field], context=self.context)\ [field]['selection'])[field_val] elif kind=='items': return self.pool.get(model) \ .fields_get(self.cr, self.uid, allfields=[field], context=self.context)\ [field]['selection'] return '' except Exception: return '' return get_selection_item
只要把以上代码加入你的报表 parser,并在构造函数 __init__() 中将其以如下格式注册到 localcontext 中:
'get_selection_item':self._get_selection_items('item'), 'get_selection_items': self._get_selection_items(),
以后在报表中调用 get_selection_item 函数即可获得 selection 字段值所对应的描述字符串:
[[ get_selection_item(object, 'state') ]]