Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.
Hi all,
I'm wondering if anybody could help out on this code, in short this code will grab and (actually refresh once published) sharepoint version history. Right now the code below uses a single record under the VersionsRelevantItemID but I would like to select all records not just one.
Does anyone please know how I can actually achieve this? All the other different codes for sharepoint version history the refresh fails due to relative path.
Really appreciate any guide on this 🙂
let
VersionsRelevantSharePointListName = "List Name",
VersionsRelevantSharePointLocation = "SharePoint Location",
VersionsRelevantItemID = "Wildcard Possbile",
RelativePathURL = Text.Combine(
{
"/_api/web/Lists/getbytitle('",
VersionsRelevantSharePointListName,
"')/items(",
Text.From(VersionsRelevantItemID),
")/versions"
}
),
Source = Xml.Tables(
Web.Contents(VersionsRelevantSharePointLocation, [RelativePath = RelativePathURL])
),
entry = Source{0}[entry],
#"Removed Other Columns2" = Table.SelectColumns(entry, {"content"}),
#"Expanded content" = Table.ExpandTableColumn(
#"Removed Other Columns2",
"content",
{"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"},
{"content"}
),
#"Expanded content1" = Table.ExpandTableColumn(
#"Expanded content",
"content",
{"properties"},
{"properties"}
),
#"Expanded properties" = Table.ExpandTableColumn(
#"Expanded content1",
"properties",
{"http://schemas.microsoft.com/ado/2007/08/dataservices"},
{"properties"}
),
#"Expanded properties1" = Table.ExpandTableColumn(#"Expanded properties", "properties", {"Title"}, {"properties.Title"})
in
#"Expanded properties1"
Solved! Go to Solution.
Hi @byte007
If you are happy with your current query's output for a single list item, I would suggest you do the following:
Here is how you could write the function :
// fnSharePointListItemVersionHistory
(SiteURL as text, ListName as text, ItemID as number ) =>
let
// Function parameters
VersionsRelevantSharePointListName = ListName,
VersionsRelevantSharePointLocation = SiteURL,
VersionsRelevantItemID = ItemID,
RelativePathURL = Text.Combine(
{
"/_api/web/Lists/getbytitle('",
VersionsRelevantSharePointListName,
"')/items(",
Text.From(VersionsRelevantItemID),
")/versions"
}
),
Source = Xml.Tables(
Web.Contents(VersionsRelevantSharePointLocation, [RelativePath = RelativePathURL])
),
entry = Source{0}[entry],
#"Removed Other Columns2" = Table.SelectColumns(entry, {"content"}),
#"Expanded content" = Table.ExpandTableColumn(
#"Removed Other Columns2",
"content",
{"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"},
{"content"}
),
#"Expanded content1" = Table.ExpandTableColumn(
#"Expanded content",
"content",
{"properties"},
{"properties"}
),
#"Expanded properties" = Table.ExpandTableColumn(
#"Expanded content1",
"properties",
{"http://schemas.microsoft.com/ado/2007/08/dataservices"},
{"properties"}
),
#"Expanded properties1" = Table.ExpandTableColumn(#"Expanded properties", "properties", {"Title"}, {"properties.Title"})
in
#"Expanded properties1"
And here is the final query containing versions per item in the list.
Note that you should create Power Query parameters Site URL and List Name first.
// ItemVersions
let
Source = SharePoint.Tables( #"Site URL" , [Implementation="2.0", ViewMode="All"]),
List = Source{[Title= #"List Name"]}[Items],
#"Select Title and ID" = Table.SelectColumns(List,{"Title", "ID"}),
#"Invoked Custom Function" = Table.AddColumn(#"Select Title and ID", "VersionHistory", each fnSharePointListItemVersionHistory(#"Site URL", #"List Name", [ID])),
#"Expanded VersionHistory" = Table.ExpandTableColumn(#"Invoked Custom Function", "VersionHistory", {"properties.Title"}, {"properties.Title"}),
#"Changed Type" = Table.TransformColumnTypes(#"Expanded VersionHistory",{{"Title", type text}, {"properties.Title", type text}})
in
#"Changed Type"
I have attached a PBIX which I tested using a dummy list created on my own SharePoint Online site.
Are you able to get something similar working?
Hi @byte007
If you are happy with your current query's output for a single list item, I would suggest you do the following:
Here is how you could write the function :
// fnSharePointListItemVersionHistory
(SiteURL as text, ListName as text, ItemID as number ) =>
let
// Function parameters
VersionsRelevantSharePointListName = ListName,
VersionsRelevantSharePointLocation = SiteURL,
VersionsRelevantItemID = ItemID,
RelativePathURL = Text.Combine(
{
"/_api/web/Lists/getbytitle('",
VersionsRelevantSharePointListName,
"')/items(",
Text.From(VersionsRelevantItemID),
")/versions"
}
),
Source = Xml.Tables(
Web.Contents(VersionsRelevantSharePointLocation, [RelativePath = RelativePathURL])
),
entry = Source{0}[entry],
#"Removed Other Columns2" = Table.SelectColumns(entry, {"content"}),
#"Expanded content" = Table.ExpandTableColumn(
#"Removed Other Columns2",
"content",
{"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"},
{"content"}
),
#"Expanded content1" = Table.ExpandTableColumn(
#"Expanded content",
"content",
{"properties"},
{"properties"}
),
#"Expanded properties" = Table.ExpandTableColumn(
#"Expanded content1",
"properties",
{"http://schemas.microsoft.com/ado/2007/08/dataservices"},
{"properties"}
),
#"Expanded properties1" = Table.ExpandTableColumn(#"Expanded properties", "properties", {"Title"}, {"properties.Title"})
in
#"Expanded properties1"
And here is the final query containing versions per item in the list.
Note that you should create Power Query parameters Site URL and List Name first.
// ItemVersions
let
Source = SharePoint.Tables( #"Site URL" , [Implementation="2.0", ViewMode="All"]),
List = Source{[Title= #"List Name"]}[Items],
#"Select Title and ID" = Table.SelectColumns(List,{"Title", "ID"}),
#"Invoked Custom Function" = Table.AddColumn(#"Select Title and ID", "VersionHistory", each fnSharePointListItemVersionHistory(#"Site URL", #"List Name", [ID])),
#"Expanded VersionHistory" = Table.ExpandTableColumn(#"Invoked Custom Function", "VersionHistory", {"properties.Title"}, {"properties.Title"}),
#"Changed Type" = Table.TransformColumnTypes(#"Expanded VersionHistory",{{"Title", type text}, {"properties.Title", type text}})
in
#"Changed Type"
I have attached a PBIX which I tested using a dummy list created on my own SharePoint Online site.
Are you able to get something similar working?
Hi Owen,
Ah, that is absolutely brilliant - thank you for the example as now (like always) it makes sense what you did 🙂
The only stumbling block is of course the dreaded refresh problem as I'm not using a gateway which is correct for this but even after looking at the following which I think is now out of date I still cannot get refresh working as it fails with login credentials. I believe it is normal as the url is not passed through correctly when testing connection.
Dynamic Web.Contents() and Power BI Refresh Errors – Data Inspirations
Thank you so much really appreciate your time and help for the fix
Hi Owen,
I managed to fix this by with a bit of adjusting, here was the final code that worked with refresh.
// fnSharePointListItemVersionHistory
(ItemID as number ) =>
let
// Function parameters
VersionsRelevantSharePointListName = "Site Pages",
VersionsRelevantItemID = ItemID,
Source = Xml.Tables(
Web.Contents(
"https://xxxxx.sharepoint.com/teams/sitename/_api/web/", [RelativePath = "Lists/getbytitle('" & VersionsRelevantSharePointListName & "')/items(" & Text.From(VersionsRelevantItemID) & ")/versions"]
)
),
entry = Source{0}[entry],
#"Removed Other Columns2" = Table.SelectColumns(entry,{"content"}),
#"Expanded content" = Table.ExpandTableColumn(#"Removed Other Columns2", "content", {"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"}, {"content"}),
#"Expanded content1" = Table.ExpandTableColumn(#"Expanded content", "content", {"properties"}, {"properties"}),
#"Expanded properties" = Table.ExpandTableColumn(#"Expanded content1", "properties", {"http://schemas.microsoft.com/ado/2007/08/dataservices"}, {"properties"})
in
#"Expanded properties"
Many thanks again 🙂
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Prices go up Feb. 11th.
Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.
User | Count |
---|---|
14 | |
13 | |
12 | |
12 | |
12 |