2016-08-04 84 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() 

我不知道为什么它的代码工作早没有提交()。