Python 名称错误:全局名称';cr和x27;未定义-从Odoov7迁移到Odoov10

Python 名称错误:全局名称';cr和x27;未定义-从Odoov7迁移到Odoov10,python,openerp,Python,Openerp,我在OpenERP v7上有此向导: class UpdateInfoPartner(models.TransientModel): _name = 'update.info.partner' def update_info(self): context = dict(self._context or {}) seniat_url_obj = self.pool.get('seniat.url') cr.execute('''SELECT id FROM res_pa

我在OpenERP v7上有此向导:

class UpdateInfoPartner(models.TransientModel):
_name = 'update.info.partner'

def update_info(self):

    context = dict(self._context or {})
    seniat_url_obj = self.pool.get('seniat.url')
    cr.execute('''SELECT id FROM res_partner WHERE vat ilike 'VE%';''')
    record = cr.fetchall()
    pids = [item[0] for item in record]
    seniat_url_obj.connect_seniat(pids, all_rif=True)
    return{}
我已成功安装此向导的源模块,但当我尝试实际运行此方法时,出现以下错误:

Traceback (most recent call last):
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 638, in _handle_exception
return super(JsonRequest, self)._handle_exception(exception)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 675, in dispatch
result = self._call_function(**self.params)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 331, in _call_function
return checked_call(self.db, *args, **kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/service/model.py", line 119, in wrapper
return f(dbname, *args, **kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 324, in checked_call
result = self.endpoint(*a, **kw)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 933, in __call__
return self.method(*args, **kw)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 504, in response_wrap
response = f(*args, **kw)
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/web/controllers/main.py", line 866, in call_button
action = self._call_kw(model, method, args, {})
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/web/controllers/main.py", line 854, in _call_kw
return call_kw(request.env[model], method, args, kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/api.py", line 681, in call_kw
return call_kw_multi(method, model, args, kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/api.py", line 672, in call_kw_multi
result = method(recs, *args, **kwargs)
File "/home/kristian/odoov10/gilda/l10n_ve_fiscal_requirements/wizard/update_info_partner.py", line 14, in update_info
cr.execute('''SELECT id FROM res_partner WHERE vat ilike 'VE%';''')
NameError: global name 'cr' is not defined
我知道这种调用
查询的方法在新的API上是不可行的,但是我如何在v10上替换它呢?它和v8不完全一样


有什么想法吗?

我用
self.env.cr
这样解决了它:

class UpdateInfoPartner(models.TransientModel):
    _name = 'update.info.partner'

def update_info(self):

    context = dict(self._context or {})
    seniat_url_obj = self.pool.get('seniat.url')
    self.env.cr.execute('''SELECT id FROM res_partner WHERE vat ilike 'VE%';''')
    record = self.env.cr.fetchall()
    pids = [item[0] for item in record]
    seniat_url_obj.connect_seniat(pids, all_rif=True)
    return{}

cr
应将光标固定在数据库上。你只是没有把它放在任何地方使用。您是否尝试过使用
\u cr
self.env.cr
?我不熟悉openerp,所以在黑暗中点击这里。嗨,是的,我用selv.env.cr解决了它。我要回答我自己的问题,谢谢