Solved

Office 365 - mass edit all users contact information

Posted on 2016-07-30
13
67 Views
Last Modified: 2016-08-02
Experts,

I am stuck on this one.... I know i need a CSV file to complete this task and already have one.  our users are all using Office 365 and I need to edit all of their contact info properties for email signature templates (using Exclaimer).   So i need to be able to add each of my users job title, direct company phone number, email address. etc...

Ive looked online for solutions and found this:
https://www.cogmotive.com/blog/office-365-tips/update-office-365-user-details-from-a-csv-file

and I can connect perfectly fine via Power shell to connect to my Office365 account.  but thats as far as I can get.  I am not a scripting expert let me say that.  lol

I am not able create the script I need to import the data fields to populate my users account info.  I'm just lost on this one and need the assistance of someone who is familiar with how to do this.  I have about 120 users that I need to update info for and would rather not have to manually do it.

The link above helps a little but not exactly to the fields that I would need.

Thank you very much for you time and assistance
0
Comment
Question by:mkavinsky
  • 5
  • 4
  • 4
13 Comments
 
LVL 78

Expert Comment

by:David Johnson, CD, MVP
ID: 41735771
what is the header line of your csv?
0
 
LVL 14

Expert Comment

by:Todd Nelson
ID: 41735831
Are your O365 users "cloud-only" users or are the accounts syncing from your on premises AD?

The reason I ask is that it will depend on how the accounts need to be edited.  If syncing from on prem, then you cannot update the user info when connected to O365 with PowerShell.
0
 

Author Comment

by:mkavinsky
ID: 41736410
Todd,

no, my users are not cloud only (not using Azure).  I have a local on premise AD Domain Controller.

David,

The header line of my CSV is just the title of each column:
Name, Title, email, phone, department
0
 
LVL 78

Expert Comment

by:David Johnson, CD, MVP
ID: 41736417
Then you would use the get-aduser/set-aduser cmdlets
0
 
LVL 14

Expert Comment

by:Todd Nelson
ID: 41736450
This following reference adds new users to AD using a CSV file but updating users is essentially the same through the use of the set-aduser command.

Add Users to AD from CSV via PowerShell ... https://oddytee.wordpress.com/2015/08/12/add-users-to-ad-from-csv-via-powershell/
0
 

Author Comment

by:mkavinsky
ID: 41736478
todd

I'm not looking at add users just edit their company and contact information  - would the same still apply?
0
Enterprise Mobility and BYOD For Dummies

Like “For Dummies” books, you can read this in whatever order you choose and learn about mobility and BYOD; and how to put a competitive mobile infrastructure in place. Developed for SMBs and large enterprises alike, you will find helpful use cases, planning, and implementation.

 

Author Comment

by:mkavinsky
ID: 41736479
david,

thank you for your response.  Sorry, but I am too savvy with the writing command line scripts.  So I am not sure how to use that line you suggested above

thanks
0
 
LVL 78

Expert Comment

by:David Johnson, CD, MVP
ID: 41736863
if the name field is indeed the samaccountname and not the display name
import-csv -path myfile.csv | set-aduser -identity $_.name   -title $_.Title -email $_.email -officephone $_.phone -Departmant $_.department 

Open in new window

https://technet.microsoft.com/en-ca/library/ee617215.aspx
0
 

Author Comment

by:mkavinsky
ID: 41737327
david,

thank you.  when I am identifying the user where you have "-identity $_.name "  am I am to use their Office 365 login (which is their email address) or their AD login name?

thanks
0
 
LVL 14

Expert Comment

by:Todd Nelson
ID: 41738036
MKavinsky,

I wasn't suggesting that you add users. The command in the article I provided as a reference is very similar to the command you will need to update users. Obviously, there are more fields that are going to be set in the following command than what you may need.

If you are syncing from your on-premises AD through AAD Connect (or DirSync or AADSync), then you have to update the users from on-premises using the Set-ADUser command; and the changes will sync to O365.

Import-Csv "C:\Users.csv" | ForEach-Object { Set-ADUser -SamAccountName $_.sAMAccountName -Department $_.Department -Company $_.Company -Fax $_.FacsimileTelephoneNumber -City $_.l -State $_.St -PostalCode $_.PostalCode -Description $_.Description -Title $_.Title }

Review the usage and parameters for Set-ADUser here ... https://technet.microsoft.com/en-us/library/ee617215.aspx


If you are not syncing from your on-premises AD through AAD Connect (or DirSync or AADSync), then you can update your O365 users via PowerShell using the the Set-MsolUser command.  The command would look similar to this for a single user…

Set-MsolUser -UserPrincipalName user1@mydomain.com -Department “My Department” -Company “My Company” -PhoneNumber “888-555-5555 -City “My City” -State “ST” -PostalCode “01234” -Description “My Description” -Title “Support Technician”

Or for users from a CSV file…

Import-Csv "C:\Users.csv" | ForEach-Object { Set-MsolUser -UserPrincipalName $_.UPN -Department $_.Department -Company $_.Company -PhoneNumber $_.PhoneNumber -City $_.City -State $_.St -PostalCode $_.PostalCode -Description $_.Description -Title $_.Title }

Review the usage and parameters for Set-MsolUser here … https://msdn.microsoft.com/en-us/library/dn194136.aspx
0
 
LVL 78

Assisted Solution

by:David Johnson, CD, MVP
David Johnson, CD, MVP earned 150 total points
ID: 41738745
thank you.  when I am identifying the user where you have "-identity $_.name "  am I am to use their
Office 365 login (which is their email address) or their AD login name?

Their samaccountname
0
 
LVL 14

Accepted Solution

by:
Todd Nelson earned 350 total points
ID: 41738954
thank you.  when I am identifying the user where you have "-identity $_.name "  am I am to use their Office 365 login (which is their email address) or their AD login name?

It depends. If you are updating the accounts on premise you can use "identity" or "samaccountname" or "userprincipalname". If you are updating directly in O365, then you have to use "userprincipalname".
0
 

Author Closing Comment

by:mkavinsky
ID: 41739532
thank you both of your for your assistance on this.   Todd, thank you for your clarity between AD and Office365.

The help was greatly appreciated and that solution worked

thanks!
0

Featured Post

Why spend so long doing email signature updates?

Do you spend loads of your time carrying out email signature updates? Not very interesting are they? Don’t let signature updates get you down. Let Exclaimer Cloud - Signatures for Office 365 make managing email signatures a breeze.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Is your Office 365 signature not working the way you want it to? Are signature updates taking up too much of your time? Let's run through the most common problems that an IT administrator can encounter when dealing with Office 365 email signatures.
Read this checklist to learn more about the 15 things you should never include in an email signature.
The video tutorial explains the basics of the Exchange server Database Availability groups. The components of this video include: 1. Automatic Failover 2. Failover Clustering 3. Active Manager
In this video I am going to show you how to back up and restore Office 365 mailboxes using CodeTwo Backup for Office 365. Learn more about the tool used in this video here: http://www.codetwo.com/backup-for-office-365/ (http://www.codetwo.com/ba…

911 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now