odoo导入功能二开

原来有的导入功能相信很多小伙伴对其功能不是很满意,不过没关系,我们可以二开啊,把它的功能改造成你想要的样子,接下来让我们看看怎么办吧

  • 例如我想把员工导入功能中添加上用户同步注册功能

  • 首先,我要找到原模块中导入时调用的模型——importUser.py文件

  • 找到这个文件之后打开 HtkjtImport 类,该类继承import基础模块

      class HtkjtImport(models.TransientModel):
    _inherit = "base_import.import"
  • 在该类下面找到 do 方法,将其重写

  • 当然咯,重写该方法或者其他方法都可以,不一定就选择这个

  • 代码风格规范一点的也可以自己新建一个方法,然后调用就可以了

    @api.multi

    def do(self, fields, columns, options, dryrun=False):

      self.ensure_one()
    self._cr.execute('SAVEPOINT import') try:
    data, import_fields = self._convert_import_data(fields, options)
    # Parse date and float field
    data = self._parse_import_data(data, import_fields, options)
    except ValueError as error:
    return {
    'messages': [{
    'type': 'error',
    'message': pycompat.text_type(error),
    'record': False,
    }]
    } _logger.info('importing %d rows...', len(data)) name_create_enabled_fields = options.pop('name_create_enabled_fields', {})
    model = self.env[self.res_model].with_context(import_file=True,
    name_create_enabled_fields=name_create_enabled_fields)
    import_result = model.load(import_fields, data)
    _logger.info('done') # If transaction aborted, RELEASE SAVEPOINT is going to raise
    # an InternalError (ROLLBACK should work, maybe). Ignore that.
    try:
    if dryrun:
    self._cr.execute('ROLLBACK TO SAVEPOINT import')
    # cancel all changes done to the registry/ormcache
    self.pool.reset_changes()
    else:
    self._cr.execute('RELEASE SAVEPOINT import')
    except psycopg2.InternalError:
    pass # 导入成功后更新插入映射列
    if import_result['ids'] and options.get('headers'):
    BaseImportMapping = self.env['base_import.mapping']
    for index, column_name in enumerate(columns):
    if column_name:
    # Update to latest selected field
    exist_records = BaseImportMapping.search(
    [('res_model', '=', self.res_model), ('column_name', '=', column_name)])
    if exist_records:
    exist_records.write({'field_name': fields[index]})
    else:
    BaseImportMapping.create({
    'res_model': self.res_model,
    'column_name': column_name,
    'field_name': fields[index]
    }) for da in data:
    print(da[1])
    print(da[3]) data = {
    'name': da[1],
    'display_name': da[1],
    'email': da[3],
    }
    partner = self.env['res.partner'].create(data)
    print(partner.id) data = {
    'login': da[3],
    'password': 123456,
    'partner_id': partner.id,
    }
    user = self.env['res.users'].create(data) return import_result
上一篇:OpenWrt路由器通过LuCI界面实现Guest SSID功能


下一篇:2012年第三届蓝桥杯Java本科组省赛试题解析