import txt file into matlab

2 Ansichten (letzte 30 Tage)
zefeng yu
zefeng yu am 14 Jan. 2017
Kommentiert: Star Strider am 15 Jan. 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

Akzeptierte Antwort

Star Strider
Star Strider am 15 Jan. 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 Kommentare
zefeng yu
zefeng yu am 15 Jan. 2017
it works well! Thank you so much!
Star Strider
Star Strider am 15 Jan. 2017
My pleasure!

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Image Analyst
Image Analyst am 14 Jan. 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 Kommentar
zefeng yu
zefeng yu am 15 Jan. 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!

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Text Data Preparation finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by