跳至內容
選單
此問題已被標幟
3 回覆
18606 瀏覽次數

Hi,

I have a situation where i need to get the XML id of a record from code.For example i need to get the XML id of a user group(Currently i have the id of that particular group).

Thanks

頭像
捨棄

Hope you are looking this:

res = self.env.ref('account.invoice_supplier_form')

最佳答案

Hi,

You can get it from the table ir.model.data by searching using the id and the model name, suppose if you have to get the external ID of the record with ID 10 in the model res.groups, search like this,

domain = [('model', '=', 'res.groups'), ('res_id', '=', 10)]
model_data = self.env['ir.model.data'].search(domain, limit=1)
xml_id = "%s.%s" % (model_data.module, model_data.name)


To see this table in the UI activate the debug mode and navigate to Settings -> Technical -> Sequence & Identifiers -> External Identifiers

You can see similar example in the odoo code itself, see the _get_external_ids function inside this file https://github.com/odoo/odoo/blob/13.0/odoo/models.py

Thanks

頭像
捨棄
最佳答案

You can browse record and call the function  get_external_id()

xmlid = record.get_external_id()


頭像
捨棄

also if you want to give an XML ID to ID by accessing Settings > Technical > Sequence & Identifiers > External Identifiers

If your record didn't exist there (by search the ID and models name), just create a new one with your preference external ID, models name, and the record ID

最佳答案

Using this answer from Ray Carnes this code works for me in Odoo 13:

https://www.odoo.com/es_ES/forum/ayuda-1/how-can-i-show-a-record-s-external-id-in-a-list-view-i-also-want-users-to-be-able-to-search-for-records-using-this-field-146080

product_id = fields.Many2one('product.product', 'Product')
prod_ext_id = fields.Char('ID Ext Product', compute='compute_ext_id_prod')
def compute_ext_id_prod(self):
for record in self:
res = record.product_id.get_external_id()
record.prod_ext_id = False
if res.get(record.product_id.id):
record.prod_ext_id = res.get(record.product_id.id)
I hope it helps!
頭像
捨棄
相關帖文 回覆 瀏覽次數 活動
1
12月 22
3721
1
6月 24
2650
0
10月 23
42856
1
10月 23
4681
2
2月 23
5176