import txt file into matlab

2 visualizaciones (últimos 30 días)
zefeng yu
zefeng yu el 14 de En. de 2017
Comentada: Star Strider el 15 de En. de 2017
Hello, everyone.
I am trying to import txt file into matlab. The txt file is generated from another software called SRIM. It contains a lot of texts in the first several paragraphs. What I want is the bottom three columns of data, namingly "target depth", "vacancies by ions", and "vacancies by recoils". Could anyone help me to obtain those data and import into matlab as a matrix? Thanks

Respuesta aceptada

Star Strider
Star Strider el 15 de En. de 2017
If all the files are the same format, and if you do not mind manually counting the 28 header lines in this one, this works:
fidi = fopen('VACANCY.txt','rt');
Dc = textscan(fidi, '%f%f%f', 'HeaderLines',29, 'CollectOutput',true, 'EndOfLine','\r\n');
fclose(fidi);
D = cell2mat(Dc); % ‘D’ Is A (100x3) Matrix Of Data
  2 comentarios
zefeng yu
zefeng yu el 15 de En. de 2017
it works well! Thank you so much!
Star Strider
Star Strider el 15 de En. de 2017
My pleasure!

Iniciar sesión para comentar.

Más respuestas (1)

Image Analyst
Image Analyst el 14 de En. de 2017
Well having "header" lines both before and after certainly makes it harder to use canned routines like importdata. You can use fgetl() to look for lines that indicate exactly what line the data you want start and stops at.
clc;
% Open the file.
fid = fopen('VACANCY.TXT');
% Search for and skip past the line '----------- ----------- ------------'
textLine = fgetl(fid);
while ischar(textLine)
disp(textLine) % OPTIONAL: Echo to command window.
textLine = fgetl(fid);
if strcmp(textLine, '----------- ----------- ------------')
break;
end
end
% Now we're into the data, but bail out if the line is a blank line (short).
row = 1;
while ischar(textLine)
disp(textLine) % OPTIONAL: Echo to command window.
textLine = fgetl(fid);
if length(textLine) < 2
% Found the blank line so bail out.
break;
end
% Extract the 3 numbers from it.
data(row, 1:3) = sscanf(textLine, '%f ');
row = row + 1;
end
% Close the file.
fclose(fid);
  1 comentario
zefeng yu
zefeng yu el 15 de En. de 2017
thank you so much for your time! It worked beyond my expectation. I only need the data though. I don't need the headlines, but it is awesome that you show me how to get it. Thanks!

Iniciar sesión para comentar.

Categorías

Más información sobre Text Data Preparation 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