Jump to content

Welcome to Smart Home Forum by FIBARO

Dear Guest,

 

as you can notice parts of Smart Home Forum by FIBARO is not available for you. You have to register in order to view all content and post in our community. Don't worry! Registration is a simple free process that requires minimal information for you to sign up. Become a part of of Smart Home Forum by FIBARO by creating an account.

 

As a member you can:

  •     Start new topics and reply to others
  •     Follow topics and users to get email updates
  •     Get your own profile page and make new friends
  •     Send personal messages
  •     ... and learn a lot about our system!

 

Regards,

Smart Home Forum by FIBARO Team


  • 0

LAU: Extract a field from


Nevicare

Question

Hi,

I want to extract a specific field from an URL-GET response. How canI do that?

The number 1794 in the example below is the value I want to collect.

That is field nr. 9, when I can use the delimiter "," 

 

My code to get the URL response is:

local http = Net.FHttp("192.168.1.75", 80);
local response = http:GET("/api/v1&limit=1");
fibaro:debug("response.."..response)

 

Then response has the following value:

[DEBUG] 15:46:36: response..[["2020-06-26 15:46:29", 1593179189, 0, 3704.64, 2881.834, 459.547, 1080.007, "P", 1794, 1662, 1778.002]]

 

How can I put this specific field in a variabele?

 

Thanks in advance.

 

Richard

 

Link to comment
Share on other sites

4 answers to this question

Recommended Posts

  • 0

Hi

I would try the following:

1st remove ALL unwanted characters from the string like maybe so: 

string.gsub(response ,  "[[" , ""  ) 

Please login or register to see this code.

 

Then use a csv parser to create a table.

like you find here:

Please login or register to see this link.

 

The result would be a table, where you can easily pick value number 9 for example

 

Hope that helps
Cheers
 

 

 

Link to comment
Share on other sites

  • 0
5 hours ago, Nevicare said:

Then response has the following value:

[DEBUG] 15:46:36: response..[["2020-06-26 15:46:29",

Please login or register to see this link.

, 0, 3704.64, 2881.834, 459.547, 1080.007, "P", 1794, 1662, 1778.002]]


This looks like the response of a P1 Monitor for measurement of power consumption. If so, there is a VD or Quickapp to extract all data. 
 


or 

 

Edited by SmartHomeEddy
Link to comment
Share on other sites

  • 0
  • Inquirer
  • Thanks for you response.

     

    @SmartHomeEddy: you are right! I created the Virtual Device. Adjusted it a little bit. It works perfect!

     

     

    Link to comment
    Share on other sites

    Join the conversation

    You can post now and register later. If you have an account, sign in now to post with your account.

    Guest
    Answer this question...

    ×   Pasted as rich text.   Paste as plain text instead

      Only 75 emoji are allowed.

    ×   Your link has been automatically embedded.   Display as a link instead

    ×   Your previous content has been restored.   Clear editor

    ×   You cannot paste images directly. Upload or insert images from URL.

    ×
    ×
    • Create New...