コンテンツへスキップ
メニュー
この質問にフラグが付けられました
8 返信
32114 ビュー

I'm not a expert but i create a tiny modules before now i'm getting this error, i have been development other models of this same module without error after two weeks, i'm asking help because I cannot find the error.


When I install the module the first time on clean database, i can create a record, but next times or if i uninstall and reinstall i cannot.


This is the error i got:

RPC_ERROR

Odoo Server Error

Traceback (most recent call last):

File "D:\OdooCDev\server\odoo\addons\base\models\ir_http.py", line 237, in _dispatch

result = request.dispatch()

File "D:\OdooCDev\server\odoo\http.py", line 688, in dispatch

result = self._call_function(**self.params)

File "D:\OdooCDev\server\odoo\http.py", line 360, in _call_function

return checked_call(self.db, *args, **kwargs)

File "D:\OdooCDev\server\odoo\service\model.py", line 94, in wrapper

return f(dbname, *args, **kwargs)

File "D:\OdooCDev\server\odoo\http.py", line 349, in checked_call

result = self.endpoint(*a, **kw)

File "D:\OdooCDev\server\odoo\http.py", line 917, in __call__

return self.method(*args, **kw)

File "D:\OdooCDev\server\odoo\http.py", line 536, in response_wrap

response = f(*args, **kw)

File "D:\OdooCDev\server\odoo\addons\web\controllers\main.py", line 1348, in call_kw

return self._call_kw(model, method, args, kwargs)

File "D:\OdooCDev\server\odoo\addons\web\controllers\main.py", line 1340, in _call_kw

return call_kw(request.env[model], method, args, kwargs)

File "D:\OdooCDev\server\odoo\api.py", line 464, in call_kw

result = _call_kw_multi(method, model, args, kwargs)

File "D:\OdooCDev\server\odoo\api.py", line 451, in _call_kw_multi

result = method(recs, *args, **kwargs)

File "D:\OdooCDev\server\odoo\models.py", line 6490, in onchange

result['value'] = snapshot1.diff(snapshot0, force=first_call)

File "D:\OdooCDev\server\odoo\models.py", line 6314, in diff

result[name] = field.convert_to_onchange(self[name], record, {})

File "D:\OdooCDev\server\odoo\fields.py", line 2836, in convert_to_onchange

if not value.id:

Exception



The above exception was the direct cause of the following exception:



Traceback (most recent call last):

File "D:\OdooCDev\server\odoo\http.py", line 644, in _handle_exception

return super(JsonRequest, self)._handle_exception(exception)

File "D:\OdooCDev\server\odoo\http.py", line 302, in _handle_exception

raise exception.with_traceback(None) from new_cause

AttributeError: '_unknown' object has no attribute 'id'

Now this is my model: 

from odoo import fields, models, api


class Expedientes(models.Model):
_inherit = ['mail.thread']
_name = 'logimpex.expedientes'
_description = 'Expedientes'
_rec_name = 'name'
_order = 'name'

# Información General del Expediente
name = fields.Char(string='Expediente', default='New', required=True, index=True)
operation_type = fields.Many2one('logimpex.operation', string='Tipo de Operación', required=True, tracking=True)
service_type = fields.Selection([('load', 'Cargo'), ('moving', 'Mudanza')],
string='Cargo / Mudanza', required=True, tracking=True)
move_type = fields.Selection([('import', 'Importación'), ('export', 'Exportación'), ('national', 'Nacional')],
string='Imp / Exp / Nac', required=True, tracking=True)
transportation_type = fields.Selection([('marine', 'Marítimo'), ('air', 'Aéreo'), ('ground', 'Terrestre')],
string='Marítimo / Aéreo / Terrestre', required=True, tracking=True)
transportation_border = fields.Many2one('logimpex.borders', string='Frontera', tracking=True)

# Información de Peso Volumen
volumen = fields.Float(string='Volumen (m³)', tracking=True)
weight = fields.Float(string='Peso (kg)', tracking=True)
weight_chargeable = fields.Float(string='Peso Cobrable (kg)', tracking=True)
pza_num = fields.Integer(string='# de Piezas', tracking=True)
amount = fields.Monetary(string='Valor', tracking=True)
currency_id = fields.Many2one('res.currency', string='Moneda', tracking=True)
note = fields.Text(string='Descripción', tracking=True)

# Información de Origen / Destino / Viaje
origin = fields.Many2one('res.country', string='Origen', required=True, tracking=True)
destiny = fields.Many2one('res.country', string='Destino', required=True, tracking=True)
start_date = fields.Date(string='Fecha Inicio', default=fields.Date.today, tracking=True)
end_date = fields.Date(string='Fecha Fin', default=fields.Date.today, tracking=True)
partner_id = fields.Many2one('res.partner', string='Cliente', required=True, tracking=True)
responsable_id = fields.Many2one('res.users', string='Responsable', tracking=True)

# Información de Seguimiento
ref = fields.Char(string='Referencia Interna', tracking=True)
pickup = fields.Char(string='Recolección', tracking=True)
load = fields.Many2one('logimpex.ports.airports', string='Carga', tracking=True)
unload = fields.Many2one('logimpex.ports.airports', string='Descarga', tracking=True)
delivery = fields.Char(string='Entrega', tracking=True)
master = fields.Char(string='Master', tracking=True)
house = fields.Char(string='House', tracking=True)
incoterm_id = fields.Many2one('account.incoterms', string='Incoterms', tracking=True)

# Campos de Documentación del Embarque
doc_embarque = fields.Binary(string="Documentos de Embarque")
doc_factura_comercial = fields.Binary(string="Factura Comercial")
doc_lista_empaque = fields.Binary(string="Lista de Empaque")
doc_blawbbol = fields.Binary(string="BL / AWB / BOL")
doc_cert_origen = fields.Binary(string="Certificado de Origen")
doc_ficha_tecnica = fields.Binary(string="Ficha Técnica")


and this is my view:





logimpex.expedientes.tree
logimpex.expedientes



























logimpex.expedientes.form
logimpex.expedientes




























































logimpex.expedientes.search
logimpex.expedientes
















































logimpex.expedientes.gantt
logimpex.expedientes

date_stop="end_date"
default_group_by='partner_id'>






Expedientes
ir.actions.act_window
logimpex.expedientes
form
tree,form,gantt


Crear tu primer registro!










アバター
破棄

Hi!

Could you check that you have added the necessary depends to your __manifest__.py? It is similar as you didn't add the dependency to the "product" module that contains the "product.template" model.

"depends": ["product"],
As a suggestion, the relation field name would be more clearer if it will have the suffix "_id" for Many2one fields and "_ids" for Many2many or One2many fields. As recommended in Odoo Developer Guidelines: https://www.odoo.com/documentation/14.0/developer/misc/other/guidelines.html?highlight=developer guideline#symbols-and-conventions

Estimados, me encuentro con licencia médica desde el lunes 26 hasta el miércoles 28
最善の回答

Please check your manifest file, file must have depends on the specified models (models used in many2one)


'depends': ['base', 'account', 'logimpex'], 

アバター
破棄
最善の回答

I had the same error and I found a misspelling in comdel_name in the inverse_name field in the line model, I was writing the definition of the field "field_id = fields.Many2one(comdel_name='" and it should be written comodel_name, so that error was raised, when I fixed this misspelling the error go away.

I hope this may help someone,

Thanks

アバター
破棄
最善の回答

Hi. In my case, I was getting the same error. It was because I had one many2one with underscore for the model name. For example, I had somehting like this:

`Many2one('project_task', ...)` Wrong

The correct way is with a dot, like this:

`Many2one('project.task', ...)` Good

アバター
破棄
最善の回答

Hi Alfonso,

Did you find the problem because i'm facing the same and i could not find the solution!?

Vincent

アバター
破棄
最善の回答

Great ! Thanks for your answer. It helps me.

アバター
破棄
最善の回答

Hi! I had the same issue and I resolved it by checking my o2m/m2o relations. I thought I wrote everything right but I made a typing error when writing the comodel's name.

I don't see all the custom models you have but I think you can check if all your m2o/o2m relations are ok.

アバター
破棄
最善の回答
I had the same problem putting a Many2one with the 'account.asset' model and the problem was that it had to depend on account_asset and not on account, because account_asset was where the 'account.asset' model was.

アバター
破棄
最善の回答

I personally had the same error too and the problem is either your one2many or many2one or many2many fields.......its likely you have misspelt the relation model 

The other scenario is either your module depends on another module that you haven't added it to depends 

アバター
破棄
関連投稿 返信 ビュー 活動
0
4月 22
3083
1
1月 24
6829
1
3月 15
5578
3
7月 25
2553
3
5月 25
4395