获取list的值有问题:
def _get_state(self, cr, uid, context=None):
idemployee = _default_employee(self, cr, uid, context=None)
# sql = " SELECT id, sequence, name FROM wf_state ORDER BY sequence "
sql = " SELECT C.id AS id, C.sequence, C.name, member_id, name_related AS employee_name,
B.name AS group_name, C.name AS state_name FROM wf_group_member A
LEFT JOIN wf_group B ON B.id = A.group_id
LEFT JOIN wf_process BB ON BB.id = B.process_id
LEFT JOIN wf_state C ON C.group_id = B.id
LEFT JOIN hr_employee D ON D.id = A.member_id
WHERE LOWER(code) = 'ca' AND member_id = %s ORDER BY sequence "
res = []
cr.execute(sql, [(idemployee)])
ardata = cr.fetchall()
for data in ardata:
# res.append((data[1], data[2]))
res.append((data[1], data[2]))
return res
array_state = _get_state
class cashadvance(osv.osv):
_name = 'ga.cashadvance'
_columns = {
'state' : fields.selection(array_state, 'Status', readonly=True, required=True),
}
_defaults={
'state' : array_state[0][0],
}
日志错误:'state': array_state[0][0],TypeError: 'function'对象没有属性'getitem_'
请帮我一下
将_defaults
更改为:
_defaults={
'state' : lambda self, cr, uid, context: array_state(self, cr, uid, context)[0][0],
}
你必须确保结果不是空的
您想调用_get_state
函数。你应该这样做:
array_state = _get_state(args...)
您省略了括号,因此您将函数对象本身赋值为array_state,而不是赋值从_get_state
返回的值。
然后你实际上尝试在函数对象上放一个索引,当然,它不支持这种操作。支持索引的对象——比如从_get_state
返回的对象——有一个叫做__getitem__
的方法。