Table of Contents
Getting all values of all items
If you want to retrieve all fieldvalues of an item, you can use following steps. I am getting the opportunities of the sales department
data:image/s3,"s3://crabby-images/41475/41475bbd863ff21c5e542e69ac752439847e00c5" alt="Getting Fieldvalues of Items 3 Screenshot of SharePoint List with values of items"
- Connect to SharePoint Online with PNP. If you don’t know how to, check the post. I am connecting with the sales site
Connect-PnPOnline -Url "https://devmodernworkplace.sharepoint.com/sites/Sales" -Interactive
- After connecting, get the list.
$Items =Get-PnPListItem -List "YourList"
I am using the list opportunities:$Items =Get-PnPListItem -List "Opportunities"
If you don’t know what the internal name of your list is, you can make use of the cmdlet$Items = Get-PNPListItem | Out-Gridview -Passthru
data:image/s3,"s3://crabby-images/8fc0b/8fc0b08c04968044f5b96e93b069a843a81c3f16" alt="Getting Fieldvalues of Items 4 out grid view with lists"
After getting the items, you can get all fieldvalues like this:$Items.Fieldvalues
data:image/s3,"s3://crabby-images/1a4b0/1a4b0fe9822586cd1474aeee8863765be6cfe416" alt="Getting Fieldvalues of Items 5 Screenshot of all values of items"
Filter items by specific value
You can filter items like this. You have to use the key, which you get with $Items. FieldValues
Filter by Where Object
$Item = $Items | Where-Object {$_.Fieldvalues["KEY"] -eq "VALUE"}
I filter for items with the title Opp 2
$Item = $Items | Where-Object {$_.Fieldvalues["Title"] -eq "Opp 2"}
Filter by -Query Parameter
I have created a separate post for this. Check it out.
Getting only specific amount of Items
It might happen, that your list contains many items. In order to get only 1000 Items, make use of the parameter -PageSize
Get-PnPListItem -List "Opportunities" -PageSize 1000
Getting a specific value for specific item
First get one single item, either by filtering, or by using the index
You can use indexing with following method
$Item= $Items[INDEX]
For the first Item: $Item = $Items[0]
For the second Item: $Item = $Items[1]
etc,
If you got a single item, you can get the fieldvalues like this:
$item.FieldValues.KEY
In my case I use the key “Product”
$item.FieldValues.Product
data:image/s3,"s3://crabby-images/e4bd6/e4bd61b267f8f324a97b47a3d36a0dba53c26169" alt="Getting Fieldvalues of Items 6 screenshot of specific value"
Or “Contact”
data:image/s3,"s3://crabby-images/ee57a/ee57a28ee77f1cdef851b0f3b3c0cbfa8c57fc7f" alt="Getting Fieldvalues of Items 7 screenshot of specific contact value"
Example script to get all fieldvalues for all items
$Url = "https://devmodernworkplace.sharepoint.com/sites/Sales" $ListName = "Opportunities" Connect-PnPOnline -Url $Url -Interactive $Items = Get-PnPListItem -List $ListName $Items.Fieldvalues
Example script to get all fieldvalues for a specific item
$Url = "https://devmodernworkplace.sharepoint.com/sites/Sales" $ListName = "Opportunities" Connect-PnPOnline -Url $Url -Interactive $Items = Get-PnPListItem -List $ListName $Item = $Items | Where-Object {$_.Fieldvalues["Title"] -eq "Opp 2"} $item.FieldValues
Pingback: Add items to SharePoint Online lists with Powershell - SPO Scripts
Pingback: Determine internal name of SharePoint Columns with GUI - SPO Scripts