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 :

Comment différencier les tirets et les moins en lecture d'un fichier txt


Sujet :

MATLAB

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2012
    Messages : 5
    Points : 6
    Points
    6
    Par défaut Comment différencier les tirets et les moins en lecture d'un fichier txt
    Bonjour,

    Je dois lire un fichier txt. En voici un exemplaire:

    BEZ;200907240940;876;22.0;1.6;66.4;283
    BEZ;200907240950;-;-12;-;-;-
    BEZ;200907241000;-;-12;-;-;-
    Et voici mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    fid = fopen(fichier);
    tab = textscan(fid,'%s%s%f%f%f%f%f','delimiter',';','TreatAsEmpty','-');
    fclose(fid);
    Vous aurez compris le souci... Dans la matrice où je stock les données (tab), Matlab me met des ''NaN'' à la place des ''-12'' et ça fait tout planter...

    Comment pourrais-je ne pas devoir supprimer ces valeurs manuelement étant donné que mon fichier comporte 230000 lignes...

    Merci pour votre aide!

  2. #2
    Membre éprouvé
    Avatar de ol9245
    Homme Profil pro
    Chercheur
    Inscrit en
    Avril 2007
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Avril 2007
    Messages : 985
    Points : 1 158
    Points
    1 158
    Billets dans le blog
    1
    Par défaut
    La solution bourrin :
    tu lis tout en '%s', sans l'option 'TreatAsEmpty','-'
    puis tu fais un str2double sur les 5 derniers champs.
    si le str2double échoue, tu mets un NaN

    C'est certain qu'il y a une solution plus élégante et, quand elle va sortir, j'aurai l'air bête avec mon code à 2 balles, mais bon... parfois, coder laid, ça soulage
    "La vraie grandeur se mesure par la liberté que vous donnez aux autres, et non par votre capacité à les contraindre de faire ce que vous voulez." Larry Wall, concepteur de Perl.

  3. #3
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    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 302
    Points : 52 882
    Points
    52 882
    Par défaut
    Une solution proche de celle de ol9245 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    fid = fopen('data.txt','r');
    tab = textscan(fid,'%*s%*d%s%s%s%s%s','delimiter',';');
    fclose(fid);
     
    X = cellfun(@str2double,tab,'uniformoutput',false);
     
    M = cell2mat(X);
    Sinon, voici une solution avec une version améliorée d'une fonction que j'avais postée précédemment :

    Téléchargez le code source : Remplacement de caractères ou de mots dans un fichier texte

    Pour transformer le fichier et lire les données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    repinfile('data.txt',{[';-' 13 10]},{[';' 13 10]});
    repinfile('new_data.txt',';-;',';;','o');
     
    fid = fopen('new_data.txt','r');
    tab = textscan(fid,'%*s%*d%f%f%f%f%f','delimiter',';','emptyvalue',NaN);
    fclose(fid);
     
    M = cell2mat(tab);
    C'est un peu moins joli, mais plus flexible
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

Discussions similaires

  1. Réponses: 2
    Dernier message: 25/03/2013, 18h24
  2. [XL-2007] Gérer les tirets parmis les valeurs d'une cellule
    Par _shuriken_ dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 13/07/2010, 14h18
  3. Réponses: 3
    Dernier message: 06/08/2009, 17h09

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