Connect Python in Excel to Power Query
For this example, I’ll connect Python to Power Query data, which is currently only supported for external data sources. i.e., you can’t connect Python in Excel to a query that references data in an Excel Table in the same file, yet!
To create a Python dataframe connected to Power Query, simply type =PY or use the keyboard shortcut CTRL+ALT+SHIFT+P then enter the following
Python formula:
DataframeName = Xl("Query Name", headers=True)
Note: Python formulas are case sensitive.
Then CTRL+ENTER to complete the formula.
As shown in the image below where my query is called QryEmployeeData:
data:image/s3,"s3://crabby-images/844b4/844b4294f1ad202c8f53e1d4db46658a4d63286c" alt="Create a Python DataFrame in Excel"
Tip: Watch the video above to see step by step how to create the query.
data:image/s3,"s3://crabby-images/14caa/14caacfd1078c5a290aca5de73eeedd08370a49f" alt=""
Set up Slicers for Python
In this example I need a Slicer for the Education Level. The Slicer selection feeds into the Python formula in Excel to filter the dataframe before loading the data to the Python chart.
In the image below I’ve created a new dataframe df2 from the PivotTable and then converted it into a list of Education Levels:
data:image/s3,"s3://crabby-images/99583/99583be3934b0d2c1b33f657e3c59ee07db5da49" alt="Convert Python DataFrame to List in Excel"
Filter Dataframes Based on Slicers
The list created in the previous step is used to create a new dataframe called filtered_df1which is based on the original dataframe df1, and will contain the Employee Data filtered for the Education Levels selected in the Slicer:
data:image/s3,"s3://crabby-images/29c72/29c726510c49a0c812fd8c700c159f43e7e465ba" alt="Create a filtered DataFrame using the list"
Note: I could have done all this filtering in the original dataframe, but then I couldn’t ever use that
dataframe in any other analysis or charts in an unfiltered state.
Create Python Charts Linked to Slicers
For this example I’m using a Seaborn Scatterplot with varying point sizes and
hues.
It references the dataframe on the ‘Workings’ sheet in cell B5, which contains the filtered results called filtered_df1 based on the Slicer selections:
data:image/s3,"s3://crabby-images/ed3fb/ed3fbb187c4a2d7a92f1437c00a9b1549a2d6fbd" alt="Python code for Seaborn Scatter Plot in Excel"
Create Pivot Charts Linked to Slicers
Next, I copied the PivotTable that captures the Slicer selection and pasted it for the Excel Pivot Chart.
By copying it, the connection to the Slicer is maintained, enabling
the Slicer to now filter both the Python chart and the Pivot Chart.
data:image/s3,"s3://crabby-images/39f80/39f80c6a4f4c3100e7af335a435d2545c684a287" alt="Copy pivot table for pivot chart"
Note: I could have
loaded the Power Query data direct to a Pivot Chart, but I like to build the PivotTable first as it’s easier to set sort orders and number formats.
Next, insert a Pivot Chart and format accordingly:
data:image/s3,"s3://crabby-images/41614/41614f776ed18e1fab3ae1ffc921ab6d2b643ca2" alt="Insert pivot chart and format it"
Tip: if you forget to copy the PivotTable and instead insert a new PivotTable, right-click on the Slicer > Report Connections > select the PivotTables from the list that you want the Slicer to filter.
IMPORTANT: For the Slicer to filter both PivotTables, they must use the same source data Table.
Limitations
Slow Files
Refreshing Python formulas can be slow to recalculate. You may find it helpful to set calculation to Partial while writing Python in Excel:
data:image/s3,"s3://crabby-images/f0d3a/f0d3a5d57a4af0ae085299f573c90c1307dffed8" alt="Set Excel Calculation Mode to Partial"
Partial Calculation puts Python and Excel Data Tables into Manual calc mode. Press F9 to force a manual calculation.
Tip: Format Stale Values will put a strikethrough any cells that haven’t been recalculated.
Python Animations
Currently Python charts like
these that use Python code for animations and interactivity are not supported in Excel.