The ultimate Fabric, Power BI, SQL, and AI community-led learning event. Save €200 with code FABCOMM.
Get registeredCompete to become Power BI Data Viz World Champion! First round ends August 18th. Get started.
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 🙂