Effacer les filtres
Effacer les filtres

Read real numbers with textread

3 vues (au cours des 30 derniers jours)
NF
NF le 4 Mai 2018
Commenté : NF le 4 Mai 2018
I have to read specific lines in a .txt file and thus I am using the function textread to do so. The problem is that the lines are composed of real numbers and then textread saves it as '0.957' and not as 0.957 (no commas). Because of that, I cannot save these data into a vector. I tried to remove the commas with regexprep but it didn't work. How can I do that? This is my code (that returns an error):
clc;
clear variables;
close all;
file=fopen('takt_times.txt','r');
nlines=0;
while (fgets(file) ~= -1),
nlines = nlines+1;
end
fclose(file);
C = textread('takt_times.txt', '%f','delimiter', '\n');
read1=2;
rowindex=1;
a=zeros(40,1);
i=1;
while rowindex < nlines
cc=C{read1};
a(i)=regexprep(cc,"'", "");
read1=read1+5;
rowindex=rowindex+5;
i=i+1;
end
a
  8 commentaires
Guillaume
Guillaume le 4 Mai 2018
Note: ' is an apostrophe (or a single quote), a comma is ,.
The code in the question differs from the code in your m file. Which do you use? %f will not output '0.957', %s will.
Reading the file twice (once to count the number of lines, once to parse it) is a waste of time. What exactly do you want to extract from the file?
NF
NF le 4 Mai 2018
I need to extract and save into a vector some of the numbers in the .txt file, that are distanciated always by the same measure, for example each 6 lines there is the one that I have to save, starting from the third line.
The lines simply are real numbers.
Example:
Line 1
Line 2
Line 3 % save
Line 4
Line 5
Line 6
Line 7
Line 8 % save
Line 9
Line 10
Line 11
Line 12
Line 13 % save
... % and so on
P.S. In the .txt file there are also lines with more thant one value, those lines are not interested in this saving.
@guillaume, yes, there are some differencies in the two because meanwhile I was trying some solutions, however the main code is quite the same. I know the %f and %s thing, I just copied the last trial I had.

Connectez-vous pour commenter.

Réponse acceptée

Guillaume
Guillaume le 4 Mai 2018
Here's how I'd do it:
wholecontent = fileread('takt_times.txt');
lines = strsplit(wholecontent, '\n')';
linestokeep = lines(3:5:end);
numbers = str2double(linestokeep);
  1 commentaire
NF
NF le 4 Mai 2018
Thanks, that's perfect

Connectez-vous pour commenter.

Plus de réponses (1)

Ameer Hamza
Ameer Hamza le 4 Mai 2018
Try using textscan() and specify format using '%f'. It will read the data as floating point numbers.
C = textscan('takt_times.txt', '%f','delimiter', '\n');
  3 commentaires
Guillaume
Guillaume le 4 Mai 2018
textread was deprecated many versions ago, but the two are more or less equivalent, the major difference being that textscan returns a cell array wheras textread returns several output.
You should be using textscan instead of textread but just changing the function will have no effect on how the file is parsed.
Ameer Hamza
Ameer Hamza le 4 Mai 2018
@NF, the textscan will load entire and separate into different parts using delimiter. So, in this case, you will get a cell array and each cell contains one line from txt file. It is same as what you will get from textread.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Text Data Preparation dans Help Center et File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by