Rather than add users manually one at a time, admins can add many users in a bulk import. To do this, you create a CSV (comma separated values) file that contains the user's data. Aside from the essential user data, such as email address and phone number, you can set user roles, define an agent's privileges, and add users to an organization. You can use bulk import to either add new users or update existing ones. Bulk import via a CSV file only works for Support users and roles.
You must be an administrator to bulk import users and organizations.
Limitations of bulk importing users and organizations
You can import a core set of data about users and organizations. For example, using bulk import, you can import the data described in the table below; however, you cannot import timezones, photos, language preferences, etc. To import data not listed in the table below, you need to use the Zendesk REST API instead. See Importing users with the Zendesk API or Importing organizations with the Zendesk API.
- The maximum number of rows depends on the import method.
- For user data and updating existing organization data, the import CSV data file can contain a maximum of 2,000 rows . That is, one header row and up to 1,999 rows of data.
- For new organization data using the Data importer (beta), the import CSV file can't exceed 1 GB in size. We recommend a maximum of 500,000 rows. That is one header row and up to 499,999 rows of data. Furthermore, each row can't exceed 128 KB in size.
- When using the Data importer, the following limitations also apply:
- The import CSV file can contain a maximum of 200 columns.
- The import CSV file can't guarantee import order for rows.
- You can only import one CSV file at a time. Therefore, if you have more data than the maximum number of rows supported for the CSV file, you must create separate files for each batch and import them one after another. When you're not using the Data importer, up to two batches are queued and run in the background. If you want to import more than two batches, you need to wait until the first batches are finished importing to add more.
- You cannot use bulk importing to import contact information from end-user Facebook or Twitter accounts. Instead, use the Zendesk REST API. See Importing users with the Zendesk API.
Creating the CSV user data file
When you create a list of users to import, you'll probably generate this list from some other user management system such as an employee database. Most of these systems have some facility for creating a CSV export file. If you need to create the list from scratch you can use a program like Microsoft Excel or OpenOffice.org Calc.
- The file must be properly formatted CSV and saved using UTF-8 character encoding.
- The first row of the CSV file is the header row, and you must include it in the file.
- The header row must contain any required fields in the table below, plus any other fields listed in the table below that you want to include.
- Included fields must appear in the header row in the order they are listed below.
- If you are not importing data for a field, do not list it in the header row.
- Empty columns of data in the file will overwrite most existing data for that user. For exceptions, see Updating existing user profile data.
- Add line breaks to notes or multiline custom fields by pressing ALT+ENTER on Windows or CTRL+OPTION+RETURN on a Mac.
The following table lists the fields that you can include in the file. The name, email, and restriction fields are all required when importing new users. When existing users are updated via bulk import, only one unique identifier is required (such as an email or external ID).
Field | Description |
---|---|
name | Required for importing new users. User's full name. |
Required for importing new users. User's full email address (someuser@mycompany.com). You can give users more than one email address. See Assigning multiple email addresses to a user. | |
external_id | If you have an ID other than the user's email address (such as an employee ID
or customer reference number), you can include it here. External IDs must be
unique for each user, or data will be overwritten. If you don’t enable Include external ID in CSV output file, external IDs are excluded from the CSV import results file (see Importing the CSV user data file). Note: If you import users with
the external_id field as their only identifier (meaning you're not also
including email address), you still need to include the email field in the CSV
file, with no data. For example:
|
details | Detailed information concerning this user, e.g. an address. This information is visible to team members only, not to end-users. |
notes | Notes concerning this user. Notes are visible to team members only, not to end users. |
phone | The user's telephone numbers. Unique phone numbers are added as direct lines. Phone numbers that already exist are added as secondary lines. To work with Talk, phone numbers should be formatted with the internationally standardized E.164 format. |
shared_phone_number | If this is a shared phone number, set to "true". A shared phone number cannot be used as a user identity. |
role | Case sensitive: "End-user", "Agent", or "Admin". If you don't set a role, the user is set to End user. |
restriction | Required for importing new users when the user's role is set to
"Agent". Restriction values of "organization" and "requested" can be
assigned when the user's role is set to "End-user".
Restriction sets the team member's or end user's privileges,
the tickets they have access to, etc. You can enter one of the following
values:
In the Enterprise version of Zendesk Support, you can also use the restriction field to assign your agent users predefined or custom roles. See Assigning an agent to an Enterprise agent role below. |
organization | The name of the organization that the user will be added to. The organization
must already exist or the import will fail. On Professional and Enterprise, you can add a user to multiple organizations by separating the organization names with a pipe character (see Importing users into multiple organizations). |
tags | When user and organization tagging has been enabled for Zendesk Support (see see Adding tags and users to organizations), you can add user tags. Separate each tag with the comma. |
brand | If the account has multiple brands, you can specify a brand subdomain. The
brand subdomain you specify determines the brand of the welcome email sent to the
user, as long as that brand is active and has an enabled help center. If the brand
subdomain you specify is not active, doesn't have an enabled help center, or
doesn't exist, the column is ignored and the welcome email is sent using default
brand. Specify only the name of the brand subdomain. For example, use mydomain and not mydomain.zendesk.com. |
custom_fields.<field key> | When you perform a bulk user import, you can import a custom user field by
specifying the custom_fields. prefix and the field key. For example, for the field key subscription_date, use the following to set the imported values for this field. custom_fields.subscription_date Note that custom field keys are case-sensitive and must be entered in lowercase letters. If you are importing information into a checkbox, enter 'true' to have it checked or 'false' to leave it unchecked. To set the value of drop-down list options, use the tag you added when you created the drop-down list. For custom date fields, use either the YY/MM/DD or YYYY-MM-DD format. To locate the key for a custom user field:
If a field value is not formatted correctly, the import will fail and you will receive an error report specifying which records failed to save. Note: If the custom user field you're importing is a lookup relationship field, enter the ID
of the related object as the value for this field. For example, for an
organization, enter the organization's ID; for a user, enter the user's ID. To
find an organization or user ID, you can export data from your account or use the
Organizations API or Users
API.
|
A note about welcome email sent to users in a bulk import
When you add new users via a bulk import, each user receives the welcome email message, if you have Guide enabled. The welcome email contains a link to verify their email address, which prompts them to select a password and then sign in.
You can prevent the welcome email from being sent to all these users by updating the welcome email setting.
To prevent the welcome email message being sent to users
- In Admin Center, click
People in the sidebar, then select Configuration > End users.
- In the User welcome email section, deselect Also send a verification email
when a new user is created by an agent or administrator.Note: This option is not available until you enable Guide.
- Click Save tab.
Importing users into multiple organizations
If you're on Professional or Enterprise, you can add users to multiple organizations during your bulk import.
Organization1|Organization2|Organization3
Here's a CSV example for adding a user to three different organizations.
"name","email","external_id","details","notes","phone","role","restriction","organization","tags"
Enrico Venticello,"venticello@somecompany.com",,,,,,,Organization1|Organization2|Organization3,,
If you list an organization that does not exist, the import will fail.
A user's default organization will be set to the first organization alphabetically. It is not possible to set a different default org using the .csv import. The default organization for a user can be adjusted manually or by using theSupport API - Set Membership as Default endpoint.
Assigning an agent to an Enterprise custom role
On Enterprise, you can assign agents custom roles. Custom roles are often used to give agents extra permissions or increased restrictions.
If you created your own custom agent roles, you can assign one of these roles to users during a bulk import by including the name of the custom role in the restriction field. In the following CSV example, a user is assigned a custom role:
"name","email","external_id","details","notes","phone","role",
"restriction","organization","tags"
Enrico Venticello,"venticello@somecompany.com",,,,,"agent","Help Desk Mastermind",,
In the example above, the user (Enrico Venticello) is given a general role ("agent"), with the additional permissions associated with the custom agent role ("Help Desk Mastermind").
Note that you must have already created the custom role in Zendesk Support before you can use it in your CSV. If you accidentally use a role name that doesn't exist in Support, the user's role defaults to Light Agent. You can then manually change the agent's role in their user profile.
Also, the import is case insensitive, which means that both of following custom role names set the agent to the same role: "Help Desk Mastermind" and "help Desk mastermind".
Assigning multiple email addresses and phone numbers to a user
In the upload file, give the same external ID (and all the user fields to be imported, for example, role) to more than one email address or phone number, as shown in the image above. All emails or calls associated with the same external ID will be routed to the user associated with that ID.
Note that when the email address matches an existing user and there are no mismatches on the external ID or phone number, that user is updated with the secondary email or new phone number. However, if any external ID, email address, or phone number matches more than one existing user, that row is rejected.
Importing the CSV user data file
You can import new users or update information for existing users.
- In Admin Center, click
People in the sidebar, then select Bulk actions > Import users.
- Select import options:
-
Create new users: This is selected by default and cannot be disabled. This is because users that exist in the import data, but not in Zendesk, will always be created.
-
Update existing users: You can additionally select this import option to replace existing data for the users listed in your CSV file.
Users' external_id or email address must be included in the CSV so that they can be identified. Other than a user identifier field, you only need to include the fields that you want to update in the file. If a user's row has a blank field, it will overwrite the existing data for that user. See Updating existing user profile data.
Note: The Send email notification to users if their password is changed option is not currently available.
-
- (Optional) Select Include external ID in CSV output file.
When the import process is complete, you will receive an email notification that includes a link to a separate CSV import results file. You can use this link to download the file and view the results of your import.
The file shows the status of the user data that you attempted to import (Created, Updated, Skipped). It includes the email address or an external ID for each user that is created or updated, depending on the contents of the file you imported and whether Include external ID in CSV output file was enabled.
If you don’t enable Include external ID in CSV output file, external IDs are excluded from the CSV import results file. External IDs are additional identifiers such as an employee number, customer reference number, or a user ID from another system. A user can only have one unique external ID. It is an optional attribute for users.
- Either click Choose File or the Let me paste in data instead link.
- Click Import.
Your import is added to the queue and the users are added to Zendesk Support when the import process is complete. See Limitations of bulk importing users and organizations. You'll receive an email when the import is complete.
Updating existing user profile data
The following user data is replaced:
- name
- external_idNote: External IDs must be unique for each user.
- role
- restriction
- organization
- Custom fields
The following user data is appended (added to the existing data):
- details
- notes
- tags
- phone (added as a secondary phone number)
- email (added as a secondary email address)
60 Comments
We were able to add a secondary email for everyone. Now my question is... Is there a method with that CSV to first remove all emails from our users and then import a new primary address?
We did add a new email but the problem is that email is not verified to all our users.
If it's possible then I will do that by evening.
Both importing users via CSV or updating users in bulk via API will add new email address as secondary one. As it turns out, there isn't any native tool that would allow you to easily change the primary email addresses for the users in a bulk.
As a workaround, you could create a custom script that uses our APIs in order to change the primary address:
Okay I see. Our government forced us to change all emails addresses in our place and many other. The @ and following changed and there is no method to change it easily. We pay tons of money to Zendesk. This is sad to ear.
Hello All,
We have a wonderful app GDPR Compliance that manages Customers and Organisations.
Hi there! I was hoping for some information regarding importing via .csv, specifically.
I create my list in Excel and format everything as it should be (I am only importing names, organization, email, and phone). I save my spreadsheet using the required UTF-8 character encoding.
Before importing the .csv file in the Admin portal, I open the file to verify the contents I am going to import. When I open this, the "phone" column is missing the required internationally standardized E.164 format (+). This is preventing any phone numbers from being imported; potentially causing duplicates in Support.
Here is my question: how can I keep the required international standardized formatting while also saving it as the required UTF-8 character encoding?
Hello,
We are a global company and in our company the default value on end-users for language is "English" and for Time zone is "GMT +01:00":
Our company has bought a new company in a different region and we are now in the process of replacing their existing support tool and migrating it to our global support platform based on Zendesk.
For this we have the need to set the language as well as the timezone during the import, because the default values are not applicable for the new users.
It seems that currently you can't define language and timezone during bulk import unfortunately - are there any plans for this to be supported in the near future?
If not, what other options/workarounds are there?
Josef Prandstetter
We can help you with the data migration.
Here is our listing https://www.zendesk.com/marketplace/apps/support/120364/help-desk-migration/
Dima Lazarchuk: you could/should know we are using your services for ticket migration multiple times so far ;) and we will use it in the future as well, because your services are part of our processes to onboard new entities - with my posts we want to state that we want to see the functionality to set language and time zone in the standard functionality without using a third-party app/service.
Is it possible to bulk import Contributor users? I can find no reference to this in any of the information above - only "End-user", "Agent", or "Admin" roles are mentioned. I have tried importing with the role set to 'Contributor' but this defaults to End-user when viewing the user in support. I am able to create a Contributor user manually, so I don't think it's an account restriction.
Unfortunately, it is not possible to bulk import users with Contributor as their role. This is due to limited permissions in this role, you can only manually change the user role after they're imported to your account as end-users. Thanks!
Hi,
i have a question, i want to create new users via the bulk importing method,
I see the fields: name, email etc....
does the external_id is option or required field?
if it is required field how do i get them if I insert new users?
It is optional. As per the article:
"If you have an ID other than the user's email address (such as an employee ID or customer reference number), you can include it . External IDs must be unique for each user, or data will be overwritten.
If you don’t enable Include external ID in CSV output file, external IDs are excluded from the CSV import results file (see Importing the CSV user data file)."
BTW, "Include external ID in CSV output file" is now called "Include external IDs in import results file".
If you have to use an external_id, activate Include external IDs in import results file when doing a bulk import. Someone at your organization should know if external IDs are used to identify users in addition to the users' email addresses.
Personally, I have not included external IDs and everything is OK with bulk imports if users.
hello,
is there any empty template available. available?
thanks
Hello,
Is it possible to use the "Bulk import users" feature to suspend existing users? Is there a column I could include in the CSV file? I tried adding the "suspended" column with the value of "true", however, it didn't suspend the user.
Thank you,
Valeriia
In all the documentation, I do not see it listed that you can bulk offboard Agents as well. It could be implied except that there is a specific checkbox needed to be selected in order to do so (i tried uploading an image but get an error that it is too big even though it is 35kb and way under 2mb)
If you go to the bottom part of the article, it will provide you the default file. It will also be advisable to do a one time export of your users so that you can have all the values for your user info.
Hi Valeriia,
I have tried it on my end and the actual bulk import option does not support suspending users. I even tried to export a suspended user but it does not have the information that it is suspended. The only option is to use the User Update API and set the suspended attribute to "true".
Is there a way to include a password during the bulk upload? As an admin I find it very tedious to edit users one by one because we want them all to have a certain password.
Unfortunately, we don't have that option for bulk import. You can look into the option of leveraging the User Password API.
Hi Zendesk team,
Can I use the bulk upload method for Alias? (on the right side on the profile section below groups) It will be helpful when we add new agents in Zendesk.
Thanks,
Monika
You should be able to use the alias property within the Users object; it is available for all of the actions related to the Users endpoints. If you're having some trouble with this, feel free to submit a ticket at any time, and we'll be glad to dive in further!
Good day! I hope you are well. Dom here chiming in for my colleague Ray.
Do you need further assistance with this query of yours? If yes, please feel free to reach out to us anytime. Thank you!
What happens on a bulk import/update when one of the CSV headers is for a field that doesn't exist? We recently had an agent import some users and they titled the column 'FullName' instead of just 'name'. Does that data just get discarded?
The import threw an error because one of the records was for a new end user, and (since name is required, and wasn't included) they got an error: "Name: is too short (minimum one character)". I noticed that the headers were wrong so we shouldn't experience the issue further - but since Zendesk didn't throw an error about the column more generally, I'm curious what happened to the data passed to a variable that doesn't exist.
You are correct. The value/field is just simply dropped from an update (discarded). We will try to update the other, genuine fields though.
Hi team, Is there an option to synchronize the customer profile data from 3rd party apps to Zendesk instead of bulk import/upload?
Potentially you can use the following API endpoints for that:
> Create Or Update User -
POST /api/v2/users/create_or_update
> Create Or Update Many Users -
POST /api/v2/users/create_or_update_many
Another idea is Setting up the Zendesk Events Connector for Amazon EventBridge
Hopefully it helps
Hi all, I have a question. If I import users with certain information from a subscription management system, does that info appears when the customer opens a new case? How would be the best way to keep that information up to date?
I want to expand my knowledge into Zendesk CRM functionalities. Can you help me?
Hello, is it possible to give access to the function "bulk import users" to people with custom roles (not Admins only)?
If not, what's a good workaround this?
Hello WeRoad, unfortunately there isn't a custom role option to set those permissions. The workaround is leveraging the API to bulk import (or use a custom app to manage user licenses).
Can the user import be augmented to allow using the external_ID of the organization to be used alternatively to the name of the organization? see below
name,email,organization_external_id
First Last,first.last@email.domain,1|2|3|4|5
For users and organizations import, the fields you can include in your CSV file are those in the article's table lists. The
organization
field cannot be replaced withorganization_external_id
. The name of the organization that the user will be added to will have to be indicated if necessary.We understand the importance of having the option to include the organization's external ID in your import file. I encourage you to create a new post in the General Product Feedback topic in our community to engage with other users who have similar needs and discuss possible workarounds. Conversations with a high level of engagement ultimately get flagged for product managers to review when they go through roadmap planning.
Please sign in to leave a comment.