Forum Discussion
MS Microsoft Graph PowerShell SDK to assign licenses in bulk from a csv file
- May 23, 2023Figure Out your SKUID's here Connect-MgGraph -Scopes User.ReadWrite.All, Directory.ReadWrite.All $CSV = Import-CSV -Path C:\Test\users.csv #-Delimiter ";" ForEach ($User in $CSV) { $UPN = $User.Email Set-MgUserLicense -UserId $UPN -AddLicenses @{SkuId = 'cb10e6cd-9da4-4992-867b-67546b1db821'} -RemoveLicenses @() } Regards Andres 
Figure Out your SKUID's here
Connect-MgGraph -Scopes User.ReadWrite.All, Directory.ReadWrite.All
$CSV = Import-CSV -Path C:\Test\users.csv #-Delimiter ";"
ForEach ($User in $CSV)
{
$UPN = $User.Email
Set-MgUserLicense -UserId $UPN -AddLicenses @{SkuId = 'cb10e6cd-9da4-4992-867b-67546b1db821'} -RemoveLicenses @()
}
Regards
Andres
my CSV files is formatted like this
email address removed for privacy reasons
email address removed for privacy reasons
email address removed for privacy reasons
email address removed for privacy reasons
I tried using your recommendation but my script is below
$CSV = Import-Csv C:\changelicense\batch01.csv #-Delimiter ";"
ForEach ($User in $CSV) {
$UPN = $User.email
Set-MgUserLicense -UserId $UPN -AddLicenses @() -RemoveLicenses @{SkuId = $Mf3Sku.SkuId}
Set-MgUserLicense -UserId $UPN -AddLicenses @{SkuId = $0e3Sku.SkuId} -RemoveLicenses @()
}
but I'm getting
Cannot convert the literal 'System.Collections.Hashtable' to the expected type 'Edm.Guid'.
what am I'm missing? thanks in advance
- Andres-BohrenJun 04, 2023Iron ContributorII think the CSV is fine Try to replace the SKU with the ID as a String "skuid" Or add $() to your SKUId Example: 
 Set-MgUserLicense -UserId $UPN -AddLicenses @{SkuId = $($0e3Sku.SkuId) }Regards Andres - emansqiJun 04, 2023Copper ContributorThanks for responding Andres-Bohren The licenses is working is use it for one email address at a time. that I'm getting error at is on -UserId errors says cannot bind because UserID is empty string. I can't seem to pull the list of email addresses from the imported CSV. when I run the command using the same address on the CSV at one time, it works. - Andres-BohrenJun 04, 2023Iron Contributor$CSV = Import-Csv C:\changelicense\batch01.csv #-Delimiter ";" 
 #Check what's in the CSV by selecting the first Item of the Array$CSV[0] 
 ForEach ($User in $CSV) {
 $UPN = $User.email
 #DebugWrite-Host "Working on: $UPN" 
 Set-MgUserLicense -UserId $UPN -AddLicenses @() -RemoveLicenses @{SkuId = $($Mf3Sku.SkuId)}
 Set-MgUserLicense -UserId $UPN -AddLicenses @{SkuId = $($0e3Sku.SkuId)} -RemoveLicenses @()
 }
 RegardsAndres