This is best Fabric, Power BI, SQL and AI community event. How do we know? The last event sold out! Save €200 with code FABCMTY200.
Register nowA new Data Days event is coming soon! This time we’re going bigger than ever. Fabric, Power BI, SQL, AI and more. Don't miss out.
Hello.
I am using an API to get the data from a Shelly device:
The script is:
let
// Define the URL
url = "https://shelly-<xx>-eu.shelly.cloud/device/status",
// Define the request body
requestBody = Text.ToBinary("id=<device_ID>&auth_key=<API_Key>"),
// Define the headers (if needed)
headers = [
#"Content-Type" = "application/x-www-form-urlencoded"
],
// Make the POST request
response = Web.Contents(url, [
Headers = headers,
Content = requestBody
]),
// Parse the JSON response
jsonResponse = Json.Document(response),
// Access the 'data' field
data = jsonResponse[data],
// Access the 'device_status' field
device_status = data[device_status],
// Convert the record to a table for easier expansion
device_status_table = Record.ToTable(device_status)
in
device_status_table
Then, my result is this:
I am trying to get the Record values in each column, but I don`t know how to do it quickly enough, and not one at a time, as the results of the API are like this:
"device_status":
{"mqtt":{"connected":false},
"switch:0":{"id":0,"aenergy":{"by_minute":[0,0,0],"minute_ts":1717071958,"total":0},"source":"init","output":false,"apower":0,"voltage":249.4,"current":0,"pf":0,"temperature":{"tC":31.3,"tF":88.4}},
"ble":[],
"id":"<device_id>",
"_updated":"2024-05-30 12:26:28",
"input:0":{"id":0,"state":false},
"v_eve:0":{"ev":"","ttl":-1,"id":0},
"eth":{"ip":null},
"ts":1717071960.41,
"code":"codeU",
"v_eve:1":{"ev":"","ttl":-1,"id":1},
"input:1":{"id":1,"state":false},
"serial":940,
"wifi":{"sta_ip":"192.x.x.x","status":"got ip","ssid":"<WiFi_name>","rssi":-65},
"cloud":{"connected":true},
"sys":{"mac":"<mac_address>","restart_required":false,"time":"11:14","unixtime":1717064091,"uptime":20691,"ram_size":238928,"ram_free":142096,"fs_size":524288,"fs_free":282624,"cfg_rev":9,"available_updates":{"stable":{"version":"1.3.2"}}}}}}
Please, could you share your experience?
Thank you.
Solved! Go to Solution.
You won't have much of a choice as you have nested records too. You will need to decide which records to keep, which to throw away, and how to flatten the hierarchies. Not really something you can do automatically.
Thank you, everyone.
I ended up adding Custom Columns based on the following formula (adapted for each column):
if
Value.Is ([Value], type record)
then
Record.Field([Value], "connected")
else
""
Resulting in:
Thank you for your support.
Hi @Alexandra_B
You can explore Record functions in Power Query from the following documentation. As all records don't share the same fields, you need to first filter the required fields and analyze which ones need to be organized into the same column. Then we can explore how to expand it more efficiently.
Record functions - PowerQuery M | Microsoft Learn
If you only want to expand all records into Text format in a column, you can try the solution from below thread:
Solved: Convert record to text in power BI - Microsoft Fabric Community
Best Regards,
Jing
If this post helps, please Accept it as Solution to help other members find it. Appreciate your Kudos!
You won't have much of a choice as you have nested records too. You will need to decide which records to keep, which to throw away, and how to flatten the hierarchies. Not really something you can do automatically.
Check out the May 2026 Power BI update to learn about new features.
Sign up to receive a private message when registration opens and key events begin.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.