تخطي للذهاب إلى المحتوى
القائمة
لقد تم الإبلاغ عن هذا السؤال
3 الردود
4919 أدوات العرض

Im trying to create several users for customers by executing a wizard from a transient Model, im creating about seven hundred users but my methods are taking too much time to complete only with one hundred. Can anyone help me to improve my methods, actually are this:

@api.multi
def create_student_user_selected(self):
    customers_ready = 0
    active_ids = self.env.context.get('active_ids', []) or []
    records = self.env['my.customers_model'].browse(active_ids)

    for customer in records:
        customers_ready += 1
        print('customer number '+ str(customers_ready))
        if customer.email and not customer.usuario_id:
            self.create_customer_user(customer)
        else:
        print('The customer has no email')

@api.multi
def create_customer_user(self, customer_id):
    customers_group = self.env.ref('stock_sales.customers_group')
    user_data = {
        'name': partner_id.name,
        'login': partner_id.email,
        'partner_id': partner_id.partner_id.id
    }
    user_customer_obj = self.env['res.users'].sudo().create(user_data)
    partner_id.sudo().write(
        {
            'user_id': user_customer_obj.id,
        }
    )
    customer_id.partner_id.email = customer_id.email 
    customers_group.users += user_customer_obj

الصورة الرمزية
إهمال

Hi,

By using sql query you can save your precious time otherwsie it will take some extra time. Because ORM will check all constrains while creating. If you don't  need to check any constrains you can follow sql query otherwsie it will take some time.

Query

create_user = """insert into res_users(name,login,partner_id) values ('%s', '%s', %d)""" % (partner_id.name, partner_id.email, partner_id.partner_id.id)

self.env.cr.execute(create_user)

Thanks.

الكاتب

ok, thanks, i will try that.

الكاتب أفضل إجابة

But the users cannot be imported.

الصورة الرمزية
إهمال

Sure they can. If you have admin privileges, you can go to Settings > Users & Companies > Users, there is an import button that allows you to import Users from a csv file.

أفضل إجابة

Hi Oscar, since this will be a one-time setup, the simplest way would be to just import the users using a csv file.

الصورة الرمزية
إهمال
المنشورات ذات الصلة الردود أدوات العرض النشاط
3
سبتمبر 20
29441
1
أبريل 24
1692
0
نوفمبر 22
1931
1
سبتمبر 20
5424
1
نوفمبر 21
2722