تخطي للذهاب إلى المحتوى
القائمة
لقد تم الإبلاغ عن هذا السؤال
2 الردود
29457 أدوات العرض

Hello, Have someone get this error; 'bool' object has no attribute '__getitem__'

الصورة الرمزية
إهمال
الكاتب

Hello Francesco, when I try this code, Ihave a keyError. Can you help me?

أفضل إجابة

This is a classic error you obtain when are you reference your pool.get to a class that doesn't exist. Read your code and search the error or post the code and we can help you.

EDIT:

Try this code for the function:

def get_convertedamount(self, cr,uid,ids,field_name,arg,context=None):
     res={}
     for pchange in self..browse(cr,uid,ids):
         res[pchange.id].update({'convertedamount' : pchange.conversionrate * pchange[.amountbeconverted})
     return res
الصورة الرمزية
إهمال
الكاتب

Hello Francesco, thank you for your answer

this is my code:

class changemanual_change(osv.osv):

def get_convertedamount(self, cr,uid,ids,field_name,arg,context=None):
       res={}
     if context is None:
         context = {}
     pchange = self.pool.get('changemanual.change').browse(cr,uid,id,)

    res['convertedamount']=pchange['conversionrate']*pchange['amountbeconverted']        
     return res

_name = 'changemanual.change'    
_columns = {
    'partner_id': fields.many2one('res.partner','Customer'),
    'currency_id'

In this line pchange = self.pool.get('changemanual.change').browse(cr,uid,id,) you call "id" but id is not defined.

أفضل إجابة

Browse objects employ object notation to access attributes. Try

pchange.conversionrate*pchange.amountbeconverted

Also I advise conditional test for existence of value.

if pchange.conversionrate and pchange.amountbeconverted:
    res['convertedamount'] = pchange.conversionrate*pchange.amountbeconverted

Otherwise you have typeerror when ORM returns False.

الصورة الرمزية
إهمال
المنشورات ذات الصلة الردود أدوات العرض النشاط
1
مارس 15
10388