how to read a textfile that contain an array of text values into matrix
4 views (last 30 days)
Show older comments
I have a textfile that contain tab delimited hexadecimal values and I would like to transfer the values into an array with each element will keep a value in the table (attached)
0 Comments
Answers (4)
Massimo Zanetti
on 16 Mar 2017
Edited: Massimo Zanetti
on 16 Mar 2017
Here is it, you should know how many columns your data span (I guessed by reading your file they are 25):
%open file
fname = 'PowerUpRampSpeed_1.txt';
fileID = fopen(fname);
%read formatted data as strings of 2 characters
A = textscan(fileID,'%2c','Delimiter','\t');
%reshape the vector to matrix size
cols = 25;
A = reshape( hex2dec(char(A)) , cols , [])';
%close file
fclose(fname);
Now, A is your matrix read into Matlab.
0 Comments
Yoav Weizman
on 20 Mar 2017
Edited: per isakson
on 2 Jun 2017
3 Comments
Walter Roberson
on 2 Jun 2017
Your solution leaves the values as text. Were you wanting a text array, or were you wanting a numeric array?
Walter Roberson
on 2 Jun 2017
Oddly, at least on OS-X, textread() is not able to read files with the original name PowerUpRampSpeed_1µs.txt claiming they do not exist . I will be filing a bug report on that.
Walter Roberson
on 2 Jun 2017
S = fileread('PowerUpRampSpeed_1µs.txt');
temp = regexp( regexp(S, '\r?\n', 'split'), '\W+', 'split');
output = vertcat(temp{:});
The result will be a 32 x 200 cell array of character vectors; hex values will not be converted to numeric.
0 Comments
See Also
Categories
Find more on Text Files in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!