2016-08-04 82 views
0

我有問題與我的代碼。Odoo。 TypeError:'int'對象不可迭代

class SiteTrip(models.Model): 
    _name = 'vips_vc.site_trip' 

    name = fields.Char() 
    session_ids = fields.One2many('vips_vc.session', 'site_trip_id', string='Session ID', index=True) 
    url_prevouse_ids = fields.Many2one('vips_vc.url_list', string='Prevouse URL', index=True) 
    url_current_ids = fields.Many2one('vips_vc.url_list', string='Current URL', index=True) 

class URLList(models.Model): 
    _name = 'vips_vc.url_list' 

    name = fields.Char(string="URL", required=True) 
    url_parametes = fields.Char(string="URL parameters") 

    target_session_id = fields.One2many('vips_vc.session', 'target_url_ids', string='Target URL') 

    site_trip_prevouse_id = fields.One2many('vips_vc.site_trip', 'url_prevouse_ids', string='Prevouse URL') 
    site_trip_current_id = fields.One2many('vips_vc.site_trip', 'url_current_ids', string='Current URL') 


    remote_sites_id = fields.One2many('vips_vc.remote_sites', 'site_url_ids', string='Remote site page with URL') 
    remote_sites_target_url_id = fields.One2many('vips_vc.remote_sites', 'target_url_ids', string='URL on remote site page') 

我的控制器:

def register_trip(self, currentURLid, prevouseURLid, sessionID): 
     currentURLid = int(currentURLid) 
     prevouseURLid = int(prevouseURLid) 
     result = None 
### something 
      _logger.info("CREATE -----> session_ids: %r url_prevouse_ids: %r url_current_ids: %r", 
          sessionID, prevouseURLid, currentURLid) 
      result = table.create({'session_ids': sessionID, 'url_prevouse_ids': prevouseURLid, 
            'url_current_ids': currentURLid}) 
### something 
     return result.id 

和錯誤是:

2016-08-04 17:20:52,931 24261 INFO odoov8 openerp.addons.vips_vc.controllers: CREATE -----> session_ids: 59 url_prevouse_ids: 8 url_current_ids: 1 
2016-08-04 17:20:52,938 24261 ERROR odoov8 openerp.http: Exception during JSON request handling. 
Traceback (most recent call last): 
    File "/home/skif/odoo/openerp/http.py", line 540, in _handle_exception 
    return super(JsonRequest, self)._handle_exception(exception) 
    File "/home/skif/odoo/openerp/http.py", line 577, in dispatch 
    result = self._call_function(**self.params) 
    File "/home/skif/odoo/openerp/http.py", line 313, in _call_function 
    return checked_call(self.db, *args, **kwargs) 
    File "/home/skif/odoo/openerp/service/model.py", line 118, in wrapper 
    return f(dbname, *args, **kwargs) 
    File "/home/skif/odoo/openerp/http.py", line 310, in checked_call 
    return self.endpoint(*a, **kw) 
    File "/home/skif/odoo/openerp/http.py", line 806, in __call__ 
    return self.method(*args, **kw) 
    File "/home/skif/odoo/openerp/http.py", line 406, in response_wrap 
    response = f(*args, **kw) 
    File "/home/skif/odoo/my-modules/vips_vc/controllers.py", line 194, in register_session 
    self.register_trip(currentURLid, prevouseURLid, sessionID) 
    File "/home/skif/odoo/my-modules/vips_vc/controllers.py", line 375, in register_trip 
    'url_current_ids': currentURLid}) 
    File "/home/skif/odoo/openerp/api.py", line 266, in wrapper 
    return new_api(self, *args, **kwargs) 
    File "/home/skif/odoo/openerp/models.py", line 4094, in create 
    record = self.browse(self._create(old_vals)) 
    File "/home/skif/odoo/openerp/api.py", line 266, in wrapper 
    return new_api(self, *args, **kwargs) 
    File "/home/skif/odoo/openerp/api.py", line 508, in new_api 
    result = method(self._model, cr, uid, *args, **old_kwargs) 
    File "/home/skif/odoo/openerp/models.py", line 4279, in _create 
    result += self._columns[field].set(cr, self, id_new, field, vals[field], user, rel_context) or [] 
    File "/home/skif/odoo/openerp/osv/fields.py", line 795, in set 
    for act in values: 
TypeError: 'int' object is not iterable 

正如你看到的,當我嘗試添加記錄在vips_vc.site_trip我收到錯誤。並且只針對currentURLid錯誤。它有整數值。 prevouseURLid也有整數值。 prevouseURLid和currentURLid具有類似的關係One2Many/Many2One。

prevouseURLid正在工作。 currentURLid不是。

在該線I檢查了所有參數(記錄器輸出):

2016-08-04 17:20:52,931 24261 INFO odoov8 openerp.addons.vips_vc.controllers: CREATE -----> session_ids: 59 url_prevouse_ids: 8 url_current_ids: 1 

url_prevouse_ids和url_current_ids具有類型爲整數。他們已經確定了價值。他們有類似的關係。並插入url_current_ids返回錯誤。 爲什麼會發生?

明天一切正常!

我沒有碰到關係。我沒有碰的變量類型...

UPD:所有操作後,我有這樣的:如果我試圖用任何參數(會話ID,prevouseURLid,currentURLid)我收到同樣的錯誤創造紀錄:類型錯誤:' int'對象不可迭代

回答

0

我發現錯誤。 我不知道它的早期如何工作的?從其它表(型號)

result = table.create({'session_ids': sessionID, 'url_prevouse_ids': prevouseURLid, 
            'url_current_ids': currentURLid}) 

在座ID記錄。當我刪除所有數據(模塊被刪除並再次安裝)。 之後,我一步一步檢查所有數據收到變量並存儲在數據庫中。我建立了vips_vc.url_list和vips_vc.session沒有數據。 之後我把這樣的代碼之後創建的所有記錄:

_logger.info(".....> Commit record ID %r", result.id) 
table.env.cr.commit() 

我不知道爲什麼它的代碼工作早沒有提交()。