Convert String array into Cell array

204 visualizaciones (últimos 30 días)
Michael Williams
Michael Williams el 15 de Mzo. de 2018
Respondida: Tarek Bekir el 5 de Sept. de 2020
I am running simulations for 16 weather stations and saving 3 simulated temperature measurements at each station. I created a large table (11000x48000) to hold simulations. I want to name each of the columns something descriptive. I was able to get the names I want into a 1x48000 string array, but I believe I have to convert it into a 1x48000 cell array to work.
varNames = join([repmat('Sim_',3*1000*16,1),(reshape(repmat(1:1000,3*16,1),[],1)),...
repmat("_Station_",3*1000*16,1),(reshape(repmat(1:16,3,1000),[],1)),...
reshape(repmat({'_Max', '_Min', '_Avg'},1000*16,1)',[],1)], "")';
simTable.Properties.VariableNames = varNames;

Respuesta aceptada

James Tursa
James Tursa el 15 de Mzo. de 2018
Is this the conversion you need?
result = arrayfun(@(x)char(varNames(x)),1:numel(varNames),'uni',false);
  1 comentario
Michael Williams
Michael Williams el 15 de Mzo. de 2018
Thanks, that worked perfectly. I had tried {result = char(varNames)}, but that gave me a character array.

Iniciar sesión para comentar.

Más respuestas (2)

Tarek Bekir
Tarek Bekir el 5 de Sept. de 2020
You can use cellstr (array)
For example
tt=["apple";"orange";"banana"];
bb={};
bb=cellstr(tt);
tt
bb
tt =
3×1 string array
"apple"
"orange"
"banana"
bb =
3×1 cell array
{'apple' }
{'orange'}
{'banana'}

Raymond MacNeil
Raymond MacNeil el 14 de Nov. de 2019
Yes, this also helped me. Thanks a lot.

Categorías

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

Community Treasure Hunt

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

Start Hunting!

Translated by