Efficient way of extracting parameters from a text file without external utilities
2 次查看(过去 30 天)
显示 更早的评论
I have a txt file whose content is as follows (There are around 1000,000 rows).
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
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
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 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Text Files 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!