Efficient way of extracting parameters from a text file without external utilities

1 次查看(过去 30 天)
I have a txt file whose content is as follows (There are around 1000,000 rows).
Capture.PNG
Basically there are 4 parameters, each of which can take non-negative integer values:
  • type 0,val1
  • type 0,val2
  • type 1,val1
  • type 1,val2
I need to extract their values and form 4 arrays one for each parameters. . How can I do this in a time efficient way?
  1 个评论
Walter Roberson
Walter Roberson 2019-7-9
This belongs as part of https://www.mathworks.com/matlabcentral/answers/470798-fastest-way-to-create-arrays-programmatically-for-particular-parameter-values-from-a-set-of-text-fi

请先登录,再进行评论。

采纳的回答

Abhilash Padma
Abhilash Padma 2019-7-17
Hi,
I understand that there is a text file which contains different values belongs to any of the 4 types.
They are:
type 0, val1 ; type 0, val2 ; type 1, val1 ; type 1, val2
You need to read all the values and store them in 4 variables where each variable belongs to different datatypes.
Try the following code, which should work for your problem.
str=fileread('test.txt');
var1=str2double(regexp(str, '(?<=type\s+0,val1\s+=\s+)\w*', 'match'));
var2=str2double(regexp(str, '(?<=type\s+0,val2\s+=\s+)\w*', 'match'));
var3=str2double(regexp(str, '(?<=type\s+1,val1\s+=\s+)\w*', 'match'));
var4=str2double(regexp(str, '(?<=type\s+1,val2\s+=\s+)\w*', 'match'));

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Text Data Preparation 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by