how to read a textfile that contain an array of text values into matrix
4 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
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 commentaires
Réponses (4)
Massimo Zanetti
le 16 Mar 2017
Modifié(e) : Massimo Zanetti
le 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 commentaires
Jan
le 16 Mar 2017
Modifié(e) : Jan
le 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 commentaires
Yoav Weizman
le 20 Mar 2017
Modifié(e) : per isakson
le 2 Juin 2017
3 commentaires
Walter Roberson
le 2 Juin 2017
Your solution leaves the values as text. Were you wanting a text array, or were you wanting a numeric array?
Walter Roberson
le 2 Juin 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
le 2 Juin 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 commentaires
Voir également
Catégories
En savoir plus sur Text Files dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!