IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MATLAB Discussion :

Importation et exploitation de valeurs provenant d'un fichier txt [Débutant]


Sujet :

MATLAB

  1. #1
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    16
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 16
    Points : 14
    Points
    14
    Par défaut Importation et exploitation de valeurs provenant d'un fichier txt
    Bonjour,

    Je suis débutant sous Matlab, et j'essaie d'écrire un petit programme permettant de récupérer des valeurs numériques (paramètres) provenant d'un fichier ".txt" afin de les réutiliser dans des formules mathématiques (fonctions) déjà existantes dans une librairie de Matlab et de tracer des graphes.

    Voici le contenu du fichier ".txt" à traiter contenant les paramètres d'entrée du problème que j'ai à traiter:

    [2:10] <----- i
    [1;0;0] <----- l
    [0;2;0] <----- B
    [6:12] <----- d

    (Rmq: les commentaires avec les flèches et i,l,B,d n'apparaissent pas en réalité, je les ai mis pour expliquer mon pb.)

    Le contenu du fichier ".txt" est directement adapté au langage de Matlab.

    Sachant que i et d sont des valeurs réelles (intervalle) et B et D des vecteurs.

    Voici les fonctions que j'utilise pour lire : i, l; B; d

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
       InputText =textscan(fid,'%s',1,'delimiter','\b');    % Lecture d'un bloc de 2 ligne.
        i=InputText{1};
        disp(i);
        InputText =textscan(fid,'%s',1,'delimiter','\b');    % Lecture d'un bloc de 3 ligne.
        l=InputText{1};
        disp(l);
        InputText=textscan(fid,'%s',1,'delimiter','\b');    % Lecture d'un bloc de 4 ligne.
        B=InputText{1};  
        disp(B);
        InputText=textscan(fid,'%s',1,'delimiter','\b');    % Lecture d'un bloc de 5 ligne.
        d=InputText{1};  
        disp(d);
    Lorsque j'execute le programme ci dessus voici ce que j'obtiens dans Matlab:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        '[2:10]'
     
        '[1;0;0]'
     
        '[0;2;0]'
     
        '[6:12]'
    Comment pourrais-je faire pour obtenir après avoir éxécuter mon fichier ".m":
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
    ans =
     
         2     3     4     5     6     7     8     9    10
     
    ans =
     
         1
         0
         0
     
    ans =
     
         0
         2
         0
     
    ans =
     
         6     7     8     9    10    11    12
    J'ai fai une recherche sur internet et je n'ai pas réussi à trouver de réponses.

    Si quelqu'un pouvait me venir en aide ça serait génial.

    Merci.

  2. #2
    Membre éprouvé
    Avatar de rostomus
    Homme Profil pro
    Doctorant électronique et traitement du signal
    Inscrit en
    Décembre 2006
    Messages
    791
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Doctorant électronique et traitement du signal

    Informations forums :
    Inscription : Décembre 2006
    Messages : 791
    Points : 1 205
    Points
    1 205
    Par défaut
    Bonjour,

    Je pense que tu dois passer par la fonction eval:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    c=textscan(fid,'%s',4,'delimiter','\b');
    fclose(fid);
    i=eval(c{1}{1});
    l=eval(c{1}{2});
    B=eval(c{1}{3});
    d=eval(c{1}{4});

  3. #3
    Expert éminent sénior
    Avatar de Caro-Line
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    9 458
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 9 458
    Points : 14 828
    Points
    14 828
    Par défaut
    Une autre solution pour éviter le eval :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    c{1}={'[2:10]','[1;0;0]','[6:12]'}
    >> b=cellfun(@str2num,c{1}, 'UniformOutput',false)
     
    b = 
     
        [1x9 double]    [3x1 double]    [1x7 double]
    %et donc tu as tes résultats dans b{i}

  4. #4
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    16
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 16
    Points : 14
    Points
    14
    Par défaut
    Bonjour,

    Merci rostomus et caro95470 pour vos réponses, je viens de faire des tests avec vos solutions et ça fonctionne très bien, c'est exactement ce que j'attendais!

    C'est super cool!

    Bonne journée

  5. #5
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 311
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 311
    Points : 52 902
    Points
    52 902
    Par défaut
    Citation Envoyé par caro95470
    Une autre solution pour éviter le eval :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    >> b=cellfun(@str2num,c{1}, 'UniformOutput',false)
    Caroline (et les autres), on peut lire dans l'aide de STR2NUM :
    CAUTION: STR2NUM uses EVAL to convert the input argument, so side
    effects can occur if the string contains calls to functions. Use
    STR2DOUBLE to avoid such side effects or when S contains a single
    number.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. lire des valeurs vides dans un fichier txt
    Par bakaratoun dans le forum MATLAB
    Réponses: 5
    Dernier message: 14/12/2009, 16h15
  2. Moyenne de valeurs contenues dans un fichier .txt
    Par romain$ dans le forum Débuter
    Réponses: 3
    Dernier message: 08/11/2008, 13h57
  3. Réponses: 7
    Dernier message: 30/10/2008, 11h31
  4. Ecrire valeurs de TextFields dans fichier txt
    Par piklas dans le forum Général Python
    Réponses: 1
    Dernier message: 30/10/2007, 13h01
  5. Réponses: 3
    Dernier message: 29/05/2006, 17h04

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo