Effacer les filtres
Effacer les filtres

How to extract data from variable

17 vues (au cours des 30 derniers jours)
Manfred
Manfred le 26 Avr 2023
Hi,
In my Mathwork Analysis module, the result of
disp(data);
shown in the command window is
{"temperature"=>10.4, "windspeed"=>12.3, "winddirection"=>255.0, "weathercode"=>3, "is_day"=>1, "time"=>"2023-04-26T14:00"}
How can I extract a single value, for example "windspeed"?
  1 commentaire
Christopher Stapels
Christopher Stapels le 26 Avr 2023
Can you show us more code? For example, how do you get the values into the variable 'data'? It looks like it might be a struct. If so, you can access the specific memebrs using dot notation
data.windspeed
for example
or
disp(data.windspeed)

Connectez-vous pour commenter.

Réponses (2)

albara
albara le 26 Avr 2023
You can extract the value associated with the "windspeed" key using MATLAB's built-in jsondecode function. Here's an example code snippet:
% Assume your JSON data is stored in a string variable named 'data'
data = '{"temperature":10.4, "windspeed":12.3, "winddirection":255.0, "weathercode":3, "is_day":1, "time":"2023-04-26T14:00"}';
% Decode the JSON data using jsondecode
json_data = jsondecode(data);
% Extract the windspeed value
windspeed = json_data.windspeed;
% Print the windspeed value to the command window
disp(windspeed);
Make sure that the JSON data is correctly formatted and that the keys and values are separated by : symbols.
Important: There may be some mistakes in this answer Experts can tell if there are any mistakes
  2 commentaires
Manfred
Manfred le 26 Avr 2023
I get the data by an webread command. There are "=>" charcters instead of ":" in the string. If i exchange them, it work like you explained.
Is there an webread option that might solve this problem?
Manfred
Manfred le 26 Avr 2023
Modifié(e) : Manfred le 26 Avr 2023
I solved the problem myself by the strrep function
data = jsondecode(strrep(data,'=>',':'));
Thank you for your helpful response.

Connectez-vous pour commenter.


Image Analyst
Image Analyst le 26 Avr 2023
What does this show:
whos data
I need to know what kind of variable it is. It doesn't look like a cell array. It looks more like a dictionary.
Does
windSpeed = data.windspeed
work?
  5 commentaires
Image Analyst
Image Analyst le 26 Avr 2023
I'd look into correcting why it put => in there instead of : in the first place. Did you create the strings, or is it something someone else made up and posted online and you need to read and parse that data?
Manfred
Manfred le 26 Avr 2023
Modifié(e) : Manfred le 26 Avr 2023
I solved the problem myself by the strrep function
data = jsondecode(strrep(data,'=>',':'));
Thank you for your helpful response.

Connectez-vous pour commenter.

Communautés

Plus de réponses dans  ThingSpeak Community

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by