如何在OpenERP(Odoo)中更改many2one字段的显示值?

ven*_*zon 1 python openerp odoo

我正在Odoo(OpenERP)上创建一个新模块,但我无法正确使用字段.

(http://i.stack.imgur.com/pKQpT.png)

我可以从另一个类中选择一个字段(在同一模块中定义),但我需要更改显示的值.

在示例中,我有字符串"menu,2",用于字段piatto.此字符串是从类ordini获得的,带有many2one字段,但我想显示名为nome的字段(如下图所示).

(http://i.stack.imgur.com/nQwRL.png)

这是python文件.

class menu(osv.Model):
_name = "menu"
_description = "Menu"
_order = "tipo"
_columns = {
    'nome': fields.char('Nome', size=80, required=True),
    'tipo': fields.selection([
                ('antipasto', 'antipasto'),
                ('primo', 'primo piatto'),
                ('secondo', 'secondo piatto'),
                ('contorno', 'contorno'),
                ('dolce', 'dolce')
                ], 'Tipo di piatto'),
    'prezzo': fields.float('Prezzo', digits=(10,2), required=True),
    'ingredienti': fields.text('Lista ingredienti'),
    'immagine': fields.binary('Immagine'),
}
_sql_constraints = [('unique_name', 'unique(nome)', 'Il piatto è già presente.')]

class ordini(osv.Model):
_name = "ordini"
_description = "Ordini"
_columns = {
    'dipendente': fields.many2one('hr.employee', 'Dipendente', ondelete='set null', required=True),
    'dettagli_ids': fields.one2many('ordini.dettagli', 'n_ordine', 'Ordine'), 
}

class ordini_dettagli(osv.Model):        
_name = "ordini.dettagli"
_description = "Dettagli ordine"
_columns = {
    'n_ordine': fields.integer('Ordine', readonly=True),
    'piatto': fields.many2one('menu', 'Piatto'),
    'qta': fields.integer('Quantità'),
    'prezzo_piatto': fields.related('piatto','prezzo',type='float',string='Prezzo',readonly=True),
}
_defaults = {
     'qta': 1,
}
Run Code Online (Sandbox Code Playgroud)

编辑我还需要在选择piatto条目时更新字段prezzo.

谢谢.

Lud*_*mer 6

您需要使用该_rec_name属性声明哪个字段用于对象名称.在你的情况下:

class menu(osv.Model):
    _name = "menu"
    _description = "Menu"
    _order = "tipo"
    _rec_name = 'nome'

    # ...
Run Code Online (Sandbox Code Playgroud)

或者,您可以重命名nomename,因为name是默认值_rec_name.