Skip to main content
Showing results for 
Search instead for 
Did you mean: 

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Helper I
Helper I

Call a REST API multiple times using Power Query


I am loading a Data Model using Power Query via a RESTful API call returning JSON data so when you look at the code generated it's something like



 Source = Json.Document(Web.Contents("https:// MY API CALL").




This dataset will then be imported into Power BI.


However in order to get my complete dataset I need to call the API a number of times by changing values in the name/value pairs of the Querystring of the API's UR so the source should behave like this,



 Source = Json.Document(Web.Contents("https:// MY API CALL 1").

 Source = Json.Document(Web.Contents("https:// MY API CALL 2").

 Source = Json.Document(Web.Contents("https:// MY API CALL 3").



Has anybody been able to get this working please?


The vendor has explained it's not possible to import all the data in one API request so I'm having to call it multiple times!


Any help or advice would be much appreciated.




You can create a function from your query using this syntax:

let functionName = (param1 as datatype) =>


 Source = Json.Document(Web.Contents("https:// MY API CALL" & param1).



in functionName


You can then create a table with your parameters and then add a custom column to your table that calls/invokes your function


You can see an example here and here

Hi @bidgeir @berta2b 

Thanks for this solution.

I got it working feeding off a REST API service. Then I wanted it to be scheduled on Power BI Service. But got this error:

Query contains unsupported function. Function name: Web.Contents


I have used 2 parameters:  (start as text, count as text) => 

Then I applied this against a list:  = List.Generate(()=>0, each _ < 67000, each _ + 1000) 

In a new query i start a custom function with Column1 = the List function and Column2 = 1000. After that I add the web-query which has the start and count params. 

The result should be it gets 1000 records at a time, otherwise it fails/time-out. 


Can you help me with the web-query refresh on PBI Service? (I am using basic auth with user and pass)


Hi @jan_k123 


Not sure this help. I've faced the similar issue, and got worked using Gateway and Skip connection


I published the entier blog, you can read it

Hi 2 all and sorry for my English!

I have a question that has been torturing for 2 days already. I have a table MYTABLE with 2 columns (URL and Index)of the form:


URL                                                                                                    Index    0    1

..................................................                                                                   1999 


In this table I have 2000 records. My goal is to get the data stored in these URLs.

For this I use the following command:

#"MyNewTable"= Table.AddColumn(#"MYTABLE", "DataFromURLsColumn", each Json.Document(Web.Contents(#"MYTABLE"{[Index]}[URL])))


, but this request is very difficult and takes a very long time. So I must wait approximately 20-30 minutes or more.

My questions is next:

1. Is there a faster way to get this data stored in the URL?
2. Perhaps there are some global or other settings in the Power BI?
3. Does this command work so slowly due to the number of queries to jira rest api, or maybe because I'm adding a new calculated column to the table?
I will be very grateful for any help, thank you in advance!

Helpful resources

July 2024 Power BI Update

Power BI Monthly Update - July 2024

Check out the July 2024 Power BI update to learn about new features.


Fabric Community Update - June 2024

Get the latest Fabric updates from Build 2024, key Skills Challenge voucher deadlines, top blogs, forum posts, and product ideas.