how to read a textfile that contain an array of text values into matrix
    11 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 Spreadsheets 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!



