extract numbers from cells

3 visualizaciones (últimos 30 días)
alessio tugnolo
alessio tugnolo el 11 de Jun. de 2021
Comentada: alessio tugnolo el 11 de Jun. de 2021
I have a cell array with n rows wich contains:
'Gain=2M'
'Gain=500k'
'Gain=20M'
....
I would extract only the number which is contained in each cell. How can I do that?

Respuestas (2)

Chunru
Chunru el 11 de Jun. de 2021
s={'Gain=2M'
'Gain=500k'
'Gain=20M'};
n = length(s);
g = zeros(n, 1);
for i=1:n
tmp = strrep(s{i}, 'Gain=', '');
g(i) = str2num(tmp(1:end-1));
switch tmp(end)
case 'M'
g(i)=g(i)*1e6;
case 'k'
g(i)=g(i)*1e3;
end
end
g
g = 3×1
2000000 500000 20000000
  1 comentario
alessio tugnolo
alessio tugnolo el 11 de Jun. de 2021
Great! It works beautifully!
Thanks

Iniciar sesión para comentar.


Stephen23
Stephen23 el 11 de Jun. de 2021
Simply download my FEX submission SIP2NUM:
and use it like this:
C = {'Gain=2M';'Gain=500k';'Gain=20M'};
V = cellfun(@sip2num,C)
V = 3×1
2000000 500000 20000000

Categorías

Más información sobre Numerical Integration and Differential Equations 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