跳至内容
菜单
此问题已终结
1 回复
41708 查看

[code]

....

   'current_stock': fields.function(_get_current_stock, type='char', string='Currently in stock'),
....


 #getting quants from stock.quant to put into field 'current_stock'

def _get_current_stock(self, cr, uid, ids, field_name, arg, context=None):

res = []

in_stock = 0

tot_sold = 0

product_id = 0

for obj in self.browse(cr, uid, ids, context=context):

#first query read data about product sold
cr.execute(""" select sum(qty) from stock_quant where product_id = %s and location_id = 7;""" %(obj.product_id.id))
tot_sold = cr.fetchall()

#second query read data adout products left in stock
cr.execute(""" select sum(qty) from stock_quant where product_id = %s and location_id != 7;""" %(obj.product_id.id))
in_stock = cr.fetchall()

res = in_stock[0]    <= once i add this, everything stops and getting error, of course if I remove it got no error but also current_stock stays empty because res = ''

# I can print value of tot_sold and in_stock
print '|| Total sell: ', tot_sold[0], ' Left in stock: ',in_stock[0]

return res

 Getting this error and don't know how to extract data from res and populate with related field 'current_stock'

new_values = dict(values)

TypeError: cannot convert dictionary update sequence element #0 to a sequence

形象
丢弃

Please use significant titles, this forum rule is also valid for newbies :-)

最佳答案

Hello Dr Obx,

I guess the problem is that you are not passing the value to associated record.

Try following code:

res[obj.id] = in_stock[0]

Reference: Function Field.

Hope this will help you.

形象
丢弃
编写者

Thank you Serpent :) Unfortunately still getting error, but this time: File "/usr/lib/python2.7/dist-packages/openerp/addons/iProdLoc/iprodloc.py", line 229, in _get_current_stock res[obj.id] = in_stock[0] IndexError: list assignment index out of range

You must check whether there are any records and then set in_stock[0]! Set like res[obj.id] = len(in_stock) !=0 and in_stock[0] or False.

编写者

So far I managed to partially solve the problem, now I don't get those errors anymore but still cant put value into my field ;)

相关帖文 回复 查看 活动
0
12月 15
3961
5
12月 23
76981
0
7月 16
4338
3
1月 16
10048
1
2月 16
4617