how to read a textfile that contain an array of text values into matrix
6 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
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 Kommentare
Antworten (4)
Massimo Zanetti
am 16 Mär. 2017
Bearbeitet: Massimo Zanetti
am 16 Mär. 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 Kommentare
Jan
am 16 Mär. 2017
Bearbeitet: Jan
am 16 Mär. 2017
fname = 'file.txt';
fid = fopen(fname, 'r');
if fid == -1
error('Cannot open file for reading: %s', fname);
end
A = fscanf(fid, '%2x', [25, inf]).';
fclose(fid);
The conversion of hexadecimal number is much faster in fscanf/sscanf then by hex2dec.
0 Kommentare
Yoav Weizman
am 20 Mär. 2017
Bearbeitet: per isakson
am 2 Jun. 2017
3 Kommentare
Walter Roberson
am 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
am 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
am 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 Kommentare
Siehe auch
Kategorien
Mehr zu Text Files finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!