March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
I would like to analyse calendar data, source is Outlook 2013. I have a series of ICS files that I export every day so I can monitor changes in bookings. Fortunately, this is only for a short period of time as there are 25 calendars to review and process.
I am familiar with the format of an ICS file but am stuck on how to get PBI to recognise the start (BEGIN:VEVENT) and end (END:VEVENT) of a calendar event so that each event is on a separate row and its elements (start/end date/time, location, organiser, attendees, subject, etc) are all in separate columns.
Hopefully this makes sense!
The code presented above by @Anonymous was a useful starter for me - thanks!
I did find it is limited to the first 15 events in the calendar.
FWIW here's my effort - it splits first onto rows which will handle an unlimited number of events.
When it splits out the columns (step: Split Column by Delimiter), I limited it to the first 14 columns, which seemed to cover all the useful data. Depending on your scenario you might need more (or less).
let
Source =Table.FromValue({Text.FromBinary( Parameter2 )}),
#"Split Column by Delimiter2" = Table.ExpandListColumn(Table.TransformColumns(Source, {{"Value", Splitter.SplitTextByDelimiter("BEGIN:VEVENT", QuoteStyle.Csv), let itemType = (type nullable text) meta [Serialized.Text = true] in type {itemType}}}), "Value"),
#"Removed Top Rows" = Table.Skip(#"Split Column by Delimiter2",1),
#"Split Column by Delimiter" = Table.SplitColumn(#"Removed Top Rows", "Value", Splitter.SplitTextByDelimiter("#(cr)#(lf)", QuoteStyle.Csv), {"Value.1", "Value.2", "Value.3", "Value.4", "Value.5", "Value.6", "Value.7", "Value.8", "Value.9", "Value.10", "Value.11", "Value.12", "Value.13", "Value.14"}),
#"Renamed Columns" = Table.RenameColumns(#"Split Column by Delimiter",{{"Value.7", "Start Date Time"}, {"Value.9", "Location"}, {"Value.13", "Subject"}, {"Value.5", "End Date Time"}}),
#"Removed Other Columns" = Table.SelectColumns(#"Renamed Columns",{"End Date Time", "Start Date Time", "Location", "Subject"})
in
#"Removed Other Columns"
Thanks for the response. Unfortunately, it doesn't answer my question and I have removed the automatic flagging of it as the accepted solution.
Per my OP "stuck on how to get PBI to recognise the start (BEGIN:VEVENT) and end (END:VEVENT) of a calendar event so that each event is on a separate row". This means I want one row per event with all the salient event information in consecutive columns.
I can import the file, that's the easy part. I need PBI to recognise the start and end tags and convert the rows between these tags into columns.
I presume this is something I will just have to do in Excel. I was hoping to not have to write loads of macros to pre-process data. I thought the USP of PBI was that it would do everything in one product.
I know this answer is two years over due, but here is some powerbi magic that can solve this issue. The trick is not to use the default Line.FromBinary and Table.FromColumn options but instead treat the input as one huge blob of text and then go to town on slicing it based on the Begin:VEVENT occurrence, then unpivot the data and finish cleaning it up. as I can't be sure in which order your columns are going to be transposed, I stopped at the split column step. feel free to continue cleaning up your columns from here.
let
Source = Table.FromValue({Text.FromBinary(Web.Contents("https://url"))}),
#"Split Column by Delimiter" = Table.SplitColumn(Source, "Value", Splitter.SplitTextByDelimiter("BEGIN:VEVENT", QuoteStyle.Csv), {"Value.1", "Value.2", "Value.3", "Value.4", "Value.5", "Value.6", "Value.7", "Value.8", "Value.9", "Value.10", "Value.11", "Value.12", "Value.13", "Value.14", "Value.15"}),
#"Unpivoted Other Columns" = Table.UnpivotOtherColumns(#"Split Column by Delimiter", {"Value.1"}, "Attribute", "Value"),
#"Split Column by Delimiter1" = Table.SplitColumn(#"Unpivoted Other Columns", "Value", Splitter.SplitTextByDelimiter("#(cr)#(lf)", QuoteStyle.Csv), {"Value.1.1", "Value.2", "Value.3", "Value.4", "Value.5", "Value.6", "Value.7", "Value.8", "Value.9", "Value.10", "Value.11", "Value.12"})
in
#"Split Column by Delimiter1"
Which file format that you choose to import the ICS file in Power BI?
Currently there is no such an approach to import that file format. The available way from my side is:
As you use Outlook 2013 as the data source here, we could directly save the calendar into .CSV file format:
Open Outlook 2013, under:
File->Open& Export->Import & Export->Export to a file->Comma separated values, after that, under your mailbox settings, choose to export Calendar.
Adding some reference:
Data sources in Power BI Desktop
Data sources for Power BI service
If any further assistance needed, please post back.
Regards,
Charlie Liao
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
User | Count |
---|---|
121 | |
77 | |
60 | |
54 | |
40 |
User | Count |
---|---|
193 | |
106 | |
88 | |
62 | |
51 |