Tutorial: Analyze Facebook data by using Power BI Desktop

In this tutorial, you learn how to import data from Facebook and use it in Power BI Desktop. You'll connect and import data from the Power BI Facebook page, apply transformations to the imported data, and use the data in report visualizations.


Due to Facebook App permission restrictions, the connector capabilities described in this article are not currently working properly. We’re working with Facebook to return this functionality as soon as possible.

Connect to a Facebook page

This tutorial uses data from the Microsoft Power BI Facebook page. You don't need any special credentials to connect and import data from this page except for a personal Facebook account.

  1. Open Power BI Desktop and select Get data in the Getting Started dialog box, or in the Home ribbon tab, select Get Data and then select More.

  2. In the Get Data dialog box, select Facebook from the Online Services group, and then select Connect.

    Get data

    A dialog box appears to alert you to the risks of using a third-party service.

    Third-party warning

  3. Select Continue.

  4. In the Facebook dialog box, enter the page name microsoftbi as the user name, select Posts from the Connection dropdown, and then select OK.


  5. When prompted for credentials, sign in to your Facebook account, and allow Power BI access to your account.


    After you connect to the Power BI Facebook page, you see a preview of the page's posts data.

    Data preview

Shape and transform the imported data

Suppose you want to see and show which posts have the most comments over time, but you notice in the posts data preview that the created_time data is hard to read and understand, and there's a lack of comments data. To pull the most out of it, perform some shaping and cleansing of the data. To do so, use the Power BI Desktop Power Query Editor to edit the data, before or after importing it into Power BI Desktop.

Split the date/time column

First, separate the date and time values in the created_time column to be more readable.

  1. In the Facebook data preview, select Edit.

    Data preview edit

    The Power BI Desktop Power Query Editor opens in a new window and displays the data preview from the Power BI Facebook page.

    Power Query Editor

  2. Select the created_time column. Notice that it's a Text data type, as denoted by an ABC icon in the column header. Right-click the header and select Split Column > By Delimiter in the drop-down list. Or, select Split Column > By Delimiter under the Transform group in the Home tab of the ribbon.

    Split column by delimiter

  3. In the Split Column by Delimiter dialog box, select Custom from the dropdown, enter T (the character that starts the time part of the created_time values) in the input field, and then select OK.

    Split Column by Delimiter dialog box

    The column splits into two columns that contain the strings before and after the T delimiter. The new columns are named created_time.1 and created_time.2, respectively. Power BI has automatically detected and changed the data types to Date for the first column and Time for the second column, and formatted the date and time values to be more readable.

  4. Rename the two columns. Select the created_time.1 column, and then select Rename in the Any Column group of the Transform tab in the ribbon. Or, double-click the column header and enter the new column name, created_date. Repeat for the created_time.2 column, and rename it created_time.

    New date and time columns

Expand the nested column

Now that the date and time data are as you want them, you can expose comments data by expanding a nested column.

  1. Select the expand icon icon at the top of the object_link column to open the Expand/Aggregate dialog box. Select connections, and then select OK.

    Expand object_link

    The column heading changes to object_link.connections.

  2. Select the expand icon icon at the top of the object_link.connections column, select comments, and then select OK. The column heading changes to object_link.connections.comments.

  3. Select the expand icon icon at the top of the object_link.connections.comments column, and this time select Aggregate instead of Expand in the dialog box. Select # Count of id, and then select OK.

    Aggregate comments

    The column now displays the number of comments for each message.

  4. Rename the Count of object_link.connections.comments.id column to Number of comments.

  5. Select the down arrow next to the Number of comments column header and select Sort Descending to see the posts sorted from most to fewest comments.

    Comments per message

Review query steps

As you shape and transform data in the Power Query Editor, each step is recorded in the Applied Steps area of the Query Settings pane at the right side of the Power Query Editor window. You can step back through the Applied Steps to see exactly what changes you made, and edit, delete, or rearrange them if necessary. Use caution when modifying these steps, because changing preceding steps can break later steps.

After applying the data transformations so far, your Applied Steps should appear as follows:

Applied Steps


Underlying the Applied Steps are formulas written in the Power Query M formula language. To see and edit the formulas, select Advanced Editor in the Query group of the Home tab of the ribbon.

Import the transformed data

When you're satisfied with the data, select Close & Apply > Close & Apply in the Home tab of the ribbon to import it into Power BI Desktop.

Close & Apply

A dialog box displays the progress of loading the data into the Power BI Desktop data model.

Loading data

Once the data is loaded, it appears in the Report view as a new query in the Fields pane.

New query

Use the data in report visualizations

Now that you have imported data from the Facebook page, you can quickly and easily gain insights about your data by using visualizations. Creating a visualization is easy, just select a field or drag it from the Fields pane onto the report canvas.

Create a bar chart

  1. In Power BI Desktop Report view, select message from the Fields pane, or drag it onto the report canvas. A table showing all post messages appears on the canvas.

    New query

  2. With that table selected, also select Number of comments from the Fields pane, or drag it into the table.

  3. Select the Stacked bar chart icon in the Visualizations pane. The table changes to a bar chart showing the number of comments per post.

    Bar chart

  4. Select More options (...) next to the visualization, and then select Sort by > Number of comments to sort the table by descending number of comments.

    Notice that the most comments were associated with (Blank) messages (these posts may have been stories, links, videos, or other non-text content).

  5. To filter out the blank rows, select message is (All) from the Filters pane, select Select all, and then select (Blank) to deselect it.

    The Filters pane entry changes to message is not (Blank), and the (Blank) row disappears from the chart visualization.

    Filter out Blank row

Format the chart

The visualization is getting more interesting, but you can't see much of the post text in the chart. To show more of the post text:

  1. Use the handles on the chart visualization to resize the chart to be as large as possible.

  2. With the chart selected, select the Format icon (paint roller) in the Visualizations pane.

  3. Select the down arrow next to Y axis, and drag the Maximum size slider all the way to the right (50%).

  4. Reduce the Text size to 10 pt to fit more text.

    Formatting changes

    The chart now shows more of the post content.

    Show more posts

The x axis (number of comments) of the chart doesn't show exact values, and looks lost at the bottom of the chart. Let's use data labels instead:

  1. Select the Format icon, and then set the slider for X axis to Off.

  2. Select the Data labels slider to On.

    Now the chart shows the exact number of comments for each post.

    Apply data labels

Edit the data type

That's better, but all the data labels have a .0 decimal place, which is distracting and misleading, because Number of posts must be a whole number. To fix them, you need to change the data type of the Number of posts column to Whole Number:

  1. Right-click Query1 in the Fields pane, or hover over it and select More options (...).

  2. From the context menu, select Edit query. Or, select Edit Queries > Edit Queries from the External data group of the Home tab in the ribbon.

  3. From the Power Query Editor window, select the Number of comments column, and change the data type by following one of these steps:

    • Select the 1.2 icon next to the Number of comments column header, and then select Whole number from the drop-down list
    • Right-click the column header, and then select Change Type > Whole Number.
    • Select Data type: Decimal Number in the Transform group of the Home tab, or in the Any Column group of the Transform tab, and then select Whole Number.

    The icon in the column header changes to 123, denoting a Whole Number data type.

    Change data type

  4. To apply the changes, select File > Close & Apply, or File > Apply to keep the Power Query Editor window open.

    After the changes load, the data labels on the chart become whole numbers.

    Chart with whole numbers

Create a date slicer

Suppose you want to visualize the number of comments on posts over time. You can create a slicer visualization to filter the chart data to different time frames.

  1. Select a blank area of the canvas, and then select the Slicer icon in the Visualizations pane.

    A blank slicer visualization appears.

    Select slicer icon

  2. Select the created_date field from the Fields pane, or drag it into the new slicer.

    The slicer changes to a date range slider, based on the field's Date data type.

    Date range slider slicer

  3. Move the slider handles to select different date ranges, and note how the chart data filters accordingly. You can also select the date fields in the slicer and type in specific dates, or choose them from a calendar popup.

    Slice data

Format the visualizations

Give the chart a more descriptive and attractive title:

  1. With the chart selected, select the Format icon in the Visualizations pane, and then select the drop-down arrow next to Title to expand it.

  2. Change the Title text to Comments per post.

  3. Select the drop-down arrow next to Font color, and select a green color to match the green bars of the visualization.

  4. Increase the Text size to 10 pt, and change the Font family to Segoe (Bold).

  5. Experiment with other formatting options and settings to change the appearance of your visualizations.


Create more visualizations

As you can see, it's easy to customize visualizations in your report to present the data in ways that you want. For example, try using the imported Facebook data to create this line chart showing the number of comments over time.

Line chart

Power BI Desktop provides a seamless end-to-end experience, from getting data from a wide range of data sources and shaping it to meet your analysis needs, to visualizing this data in rich and interactive ways. When your report is ready, you can upload it to the Power BI service and create dashboards based on it to share with other Power BI users.

Next steps