Power BI R Script allows using R visuals or R charts inside your Power BI dashboard. Using R script inside the Power BI is very helpful for the data scientists to place their work in one place.
In this section, we show you how to create a chart using Power BI R Script with example. For this Power BI R Script demonstration, we are going to use the Faithful CSV file created by R studio.
I suggest you refer R Programming to understand the code that we used in this Power BI article.
data:image/s3,"s3://crabby-images/36100/36100e0ebb99122c6238da57c2495d0d8691fe55" alt="Power BI R Script 1"
Create a Power BI R Script Visual
In Power BI, you can use this R Script Visual to create R Charts inside a Power Bi dashboard.
data:image/s3,"s3://crabby-images/969a2/969a239fc144ed839b532ec1da5c0b7bd7cc7a45" alt="Power BI R Script 2"
First, click on the R Script Visual under the Visualization section. It automatically creates an R Chart with an R script editor, as shown in the below screenshot.
You have to use this R script editor window to write R script.
data:image/s3,"s3://crabby-images/197b0/197b0bd0580ad01ac8743e22f5453efd4a7e8a34" alt="Power BI R Script 3"
Before you start writing R code, you have to create a data set. It can be done by dragging the required fields to the Values section. For this demo, let me drag eruptions and waiting columns to the Values section.
data:image/s3,"s3://crabby-images/f697f/f697f21b3bc2763755e871731c29739def1a5cc2" alt="Power BI R Script 4"
As you can see from the above screenshot, Power BI has automatically generated a data set for you. Now, you have to use this data set to create your R visual.
Here, we used ggplot2 to create 2D scatter plot. I suggest you refer, Create a Scatter Plot article to understand this code.
library(ggplot2) ggplot(dataset, aes(x = eruptions, y = waiting)) + geom_point() + geom_density_2d()
Once you finished writing your script, click the Run button
data:image/s3,"s3://crabby-images/bd207/bd207b901a4d841ed69343bbc4eaca977a296237" alt="Power BI R Script 5"
From the screenshot below, you can see the R Chart.
data:image/s3,"s3://crabby-images/59a14/59a143cc45e4ec32c19711bb8102ba36ffe9f706" alt="Power BI R Script 6"
Like any other chart in Power BI, you can apply filters on the R chart as well. To demonstrate the Power BI R script filters, let me create a table first.
data:image/s3,"s3://crabby-images/df94a/df94a7264a0a011122cdf58e675e77965b1f2ec9" alt="Power BI R Script 7"
We created a column chart, as well.
data:image/s3,"s3://crabby-images/3b01e/3b01ec81584ebe1d9a886645eb0e24d123c5a732" alt="Power BI R Script 8"
I think there is too much data in the table to apply filters. So, let me create a cluster.
data:image/s3,"s3://crabby-images/bdc0e/bdc0eb2c044c4a42ca4cbbc31c29816babca8f4c" alt="Power BI R Script 9"
We are leaving the default settings
data:image/s3,"s3://crabby-images/9cc57/9cc57784981ff6e95231dd58194060602e2be6ff" alt="Power BI R Script 10"
As you can see, it has created two clusters. Next, we replaced the Sno with the Cluster column in a Table
data:image/s3,"s3://crabby-images/6447b/6447ba789ddd5d3e50848161e337392a88226ca7" alt="Power BI R Script 11"
Let me select the Cluster 1. From the screenshot below, you can see that the R visual is filtering.
data:image/s3,"s3://crabby-images/a439a/a439abb3884383a0b25c6f522078ac21fc3494af" alt="Power BI R Script 12"
Try with the other cluster too
data:image/s3,"s3://crabby-images/36ea9/36ea925d90a112063b9ee4f031b4efdffdfe17ac" alt="Power BI R Script 13"
Create a Power BI R Script Visual 2
In Power BI, you can also create an R visual with default datasets available in R. To demonstrate the same, we are using the Diamonds data set.
library(ggplot2) ggplot(diamonds, aes(x = carat, y = price, color = cut)) + geom_point() + geom_smooth(method = "auto", se = FALSE) + scale_color_manual(values = c("orchid", "chocolate4", "goldenrod2", "tomato2", "midnightblue"))
From the screenshot below, you can see the R Script in the report.
data:image/s3,"s3://crabby-images/1d340/1d3400cdb3984cdd19a813ef13e937f0dc80c5f4" alt="Power BI R Script 14"