extracting specific part from txt file

8 次查看(过去 30 天)
I need to create column from attached txt file as follows;
a=[87.5;85;82.5;80]; %for each LAT/LON1/LON2/DLON/H
%The txt file's column number is variable.

采纳的回答

Cedric
Cedric 2015-9-3
编辑:Cedric 2015-9-3
It is difficult to understand what "for each .." means in your question. If you just need to extract the numbers that you specified, the following is one possible approach:
content = fileread( 'trial.txt' ) ;
matches = regexp( content, '[-\d\.]+(?=-\d)', 'match' ) ;
data = str2double( matches ) ;
which outputs
>> data
data =
87.5000 85.0000 82.5000 80.0000
It may not be the most efficient in term of speed, but it is very concise.. could even be a one liner:
data = str2double( regexp( fileread('trial.txt'), '[-\d\.]+(?=-\d)', 'match' )) ;

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 String Parsing 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by