Need to convert char to struct

12 visualizaciones (últimos 30 días)
Paul
Paul el 13 de Abr. de 2014
Comentada: Azzi Abdelmalek el 13 de Abr. de 2014
I am trying to use a trading algorithm and I need to check prices daily. I can download the prices manually and load them into matlab manually, but I don't want to do that every single day. I get the data from quandl.com and when I use urlread on the data file, it returns a char of the data with each value separated with a comma. How can I convert this to a structured array in my program? Should I be using a different command besides urlread for this? I've tried using struct() on the char variable but is doesn't work.

Respuestas (2)

Walter Roberson
Walter Roberson el 13 de Abr. de 2014
I recommend using regexp() with the 'split' option to get the text for each number into its own cell array entry, and then str2double() the overall cell array to get the numeric values. Or if you know exactly how many data values are expected, you could sscanf() on the strings.
  3 comentarios
Walter Roberson
Walter Roberson el 13 de Abr. de 2014
ewa2 = regexp(ewa, ',\s*', 'split');
ewa3 = str2double(ewa2);
Paul
Paul el 13 de Abr. de 2014
ewa = urlread('http://www.quandl.com/api/v1/datasets/GOOG/NYSEARCA_EWA.csv?column=4');
ewa2 = regexp(ewa, ',\s*', 'split');
ewa3 = str2double(ewa2);
This gives me a 1 x 4098 double of NaN's as ewa3. You can look at the data I'm dealing with by opening the link: http://www.quandl.com/api/v1/datasets/GOOG/NYSEARCA_EWA.csv?column=4

Iniciar sesión para comentar.


Azzi Abdelmalek
Azzi Abdelmalek el 13 de Abr. de 2014
str='12.03,23,25,26,30'
a=struct('data',num2cell(str2double(regexp(str,'[\w\.]+','match'))))
  4 comentarios
Image Analyst
Image Analyst el 13 de Abr. de 2014
I think you mean "dates" since date is the name of a built in function.
Azzi Abdelmalek
Azzi Abdelmalek el 13 de Abr. de 2014
Exact

Iniciar sesión para comentar.

Categorías

Más información sobre Data Type Conversion en Help Center y File Exchange.

Etiquetas

Aún no se han introducido etiquetas.

Community Treasure Hunt

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

Start Hunting!

Translated by