how to read a textfile that contain an array of text values into matrix
5 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
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 Commenti
Risposte (4)
Massimo Zanetti
il 16 Mar 2017
Modificato: Massimo Zanetti
il 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 Commenti
Jan
il 16 Mar 2017
Modificato: Jan
il 16 Mar 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 Commenti
Yoav Weizman
il 20 Mar 2017
Modificato: per isakson
il 2 Giu 2017
3 Commenti
Walter Roberson
il 2 Giu 2017
Your solution leaves the values as text. Were you wanting a text array, or were you wanting a numeric array?
Walter Roberson
il 2 Giu 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
il 2 Giu 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 Commenti
Vedere anche
Categorie
Scopri di più su Text Files in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!