Find specific vector in different text files

Hello everybody!
I have several different text-files, which look very similar but have minor differences. I have created a dummy text file, to show you how my files look:
Note: Everything in this dummy is "fake".
Now I have a huge number of files like this. But the only thing I need is the distance vector which is named "Distance" in every file.
I tried this code, but it doesn't work so far:
[pathstr,filename{actualfilenumber},ext] = fileparts(files{actualfilenumber});
complete_file_name{actualfilenumber} = fullfile(Path,char([filename{actualfilenumber},ext]));
actualfile = textscan(complete_file_name{actualfilenumber},'%s');
Distance = double(actualfile(:,find(ismember('Distance',actualfile))));
Any suggestions?
Cheers Christian

댓글 수: 2

KSSV
KSSV 2017년 1월 27일
Attach your text file here...
Christian
Christian 2017년 1월 27일
Here are two dummy files:

댓글을 달려면 로그인하십시오.

 채택된 답변

Guillaume
Guillaume 2017년 1월 27일

1 개 추천

filecontent = fileread('DummyText1.txt');
distances = str2double(strsplit(regexp(filecontent, '(?<=Distance.*[\n\r]+)[ 0-9.\n\r]*(?=/Distance)', 'match', 'once', dotexceptnewline')));
distances(isnan(distances)) = [];
As long as the distance numbers are not signed and not in scientific notations. To support signed numbers replace [ 0-9.\n\r] by [-+ 0-9.\n\r]. To support scientific notation in addition, replace it with [-+ 0-9.e\n\r].

추가 답변 (1개)

KSSV
KSSV 2017년 1월 27일

0 개 추천

fid = fopen('your text file') ;
distance = textscan(fid,'%f','Headerlines',15,'delimiter','\n') ;
fclose(fid) ;

댓글 수: 6

Christian
Christian 2017년 1월 27일
The problem is, the distance-vector does NOT start at line 15 all the time. Sometimes there are 30 lines of additional information above sometimes none.
KSSV
KSSV 2017년 1월 27일
편집: KSSV 2017년 1월 27일
Okay..it can be sorted...Attach one text file....
Christian
Christian 2017년 1월 27일
I have just attached two dummy files to the question!
KSSV
KSSV 2017년 1월 27일
편집: KSSV 2017년 1월 27일
fid = fopen('Dummy_Text1.txt') ;
S = textscan(fid,'%s','delimiter','\n') ;
fclose(fid) ;
S = S{1} ;
% find position of distance
idx = strfind(S, 'Distance');
idx = find(not(cellfun('isempty', idx)));
% get distance array
distance = cell2mat(S(idx(1)+1:idx(2)-1)) ;
distance = str2num(distance) ;
Well, that does not work:
Attempted to access idx(1); index out of bounds because numel(idx)=0.
Error in Dummy (line 14)
distance = cell2mat(S(idx(1)+1:idx(2)-1));
KSSV
KSSV 2017년 1월 27일
It did work for the dummy text files you have attached....

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Text Data Preparation에 대해 자세히 알아보기

태그

질문:

2017년 1월 27일

댓글:

2017년 1월 27일

Community Treasure Hunt

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

Start Hunting!

Translated by