I really appreciate someone tell me how can I convert attached file to double.
Thanks in advance.

 Respuesta aceptada

Geoff Hayes
Geoff Hayes el 8 de Abr. de 2020

0 votos

Farshid - try using cellfun. It seems that the pn is a cell array with 38 elements and each element is a 8x1 char array. You haven't mentioned if each of the 8 characters is a single number or if all 8 combine to one (I'll assume the latter).
>> myData = load('example.mat');
>> numericData = cellfun(@(x)str2double(x'), myData.pn);

8 comentarios

Farshid Daryabor
Farshid Daryabor el 8 de Abr. de 2020
Please check array 16 "numericData(16)" it is array I have problem. Please take a look at myData.pn(16).
Geoff Hayes
Geoff Hayes el 8 de Abr. de 2020
I'm not sure what your question is? The data looks like
>> myData.pn{16}
ans =
66
99
00
11
99
65
29
That is how it is in your example.mat file. And the way I've coded this is so that this gets converted to 66990011996529. Are you expecting two numbers like 6901962 and 6901959?
Farshid Daryabor
Farshid Daryabor el 8 de Abr. de 2020
Are you expecting two numbers like 6901962 and 6901959? YES, I expect to be in two different column
Geoff Hayes
Geoff Hayes el 8 de Abr. de 2020
sigh. you can do something like
>> myData = load('example.mat');
>> numericData = cell2mat(cellfun(@(y)arrayfun(@(x)str2double(y(:,x)'),1:size(y,2))', myData.pn,'UniformOutput',false));
which works for this data set but I don't know if it will work for other sets. It uses cellfun to evaluate each cell in your myData.pn cell array. This evaluation uses arrayfun to evaluate each column in the char array - first taking the transpose of the column and then converting it to a double.
Farshid Daryabor
Farshid Daryabor el 9 de Abr. de 2020
Dear Geoff,
It's working, but I want to keep a size something like 2*38. please see the form of the 'lon' attached. Since the each array of 'pn' (platform number) should be assigned to the one longitude and latitude correspondingly.
I really appreciate any comment to improve.
Farshid Daryabor
Farshid Daryabor el 9 de Abr. de 2020
should be in two row exactly same form of lon and lat
Geoff Hayes
Geoff Hayes el 9 de Abr. de 2020
Farshid - it probably would have been easier if you had just asked for that format in the first place.
myData = load('example.mat');
myOutputData = nan(2,length(myData.pn));
for k = 1:length(myData.pn)
data = myData.pn{k};
myOutputData(1,k) = str2double(data(:,1)');
if size(data,2) == 2
myOutputData(2,k) = str2double(data(:,2)');
end
end
Farshid Daryabor
Farshid Daryabor el 9 de Abr. de 2020
Dear Geoff,
I really appreciate, veryyyyygoodddddddddd

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Etiquetas

Preguntada:

el 8 de Abr. de 2020

Comentada:

el 9 de Abr. de 2020

Community Treasure Hunt

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

Start Hunting!

Translated by