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 :

Lire différents formats de nombres (séparateurs décimaux différents) avec la même fonction


Sujet :

MATLAB

  1. #1
    Futur Membre du Club
    Inscrit en
    Avril 2012
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 9
    Points : 5
    Points
    5
    Par défaut Lire différents formats de nombres (séparateurs décimaux différents) avec la même fonction
    Bonjour,

    Le titre du sujet ne veut a peu près rien dire mais j'espère que vous arriverez jusque là.

    Voici donc le problème. Je dois importer et traiter des gros sets de données, le problème est que le format des nombres dans ces données n'est pas toujours le même. En l'occurence, parfois le '.' est le séparateur décimal, parfois c'est la ','.

    En gros une ligne donne soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1741480 30.04.2012 00:00:00;   5.348;   0.602;  -0.334; -0.401;  2.607; -1.493;    2.34;  -295.67;      0;      0;      0;1;0;0
    soit

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    236897  01.05.2012 00:00:38;3,343;2,139;-1,604;-0,334;2,874;-1,025;3,409;-370,847;-2,511;-0,433;-0,268;1;0;0
    Ce qui m'intéresse de récupérer dans ces fichiers, ce sont les données après le n° de mesure , la date et l'heure : en gros tout ce qui est après le premier point virgule.

    Pour l'instant j'ai ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    C=textscan(fid,'%*s %f %f %f %f %f %f %f %f %f %f %f %f %f %f','Delimiter',';');
    Pour les données dont le spérateur décimal est le point, pas de soucis. Pour les autres, ça coince ...

    Donc : questions
    Une autre manière de prendre le problème ?
    Une formule magique ?
    Ca vaut le coup de se prendre la tête avec des REGEXP ?
    Y'a un réglage dans MATLAB pour accepter différents séparateurs décimaux?

    Je précise : pas la peine de faire du strrep, ça ralenti trop mon chargement de données, je peux pas me le permettre puis ... y'a forcément une solution plus élégante !

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Cf cette discussion.

  3. #3
    Futur Membre du Club
    Inscrit en
    Avril 2012
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Merci tout de même mais je précisais que je ne pouvais pas faire du strrep

  4. #4
    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 : 53 165
    Points
    53 165
    Par défaut
    Quelque soit la méthode utilisé, il faudra de toute façon traiter les "," individuellement.

    Une autre solution sans STRREP pour remplacer les virgules par des points dans le fichier d'origine :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    bufsize = 1024;
    fid = fopen('data.txt','r+');
    while ~feof(fid)
        [x,c] = fread(fid,[1,bufsize]);
        idx = (x==',');
        if any(idx)
            fseek(fid,-c,'cof');
            x(idx) = '.';
            fwrite(fid,x);
        end
    end
    fclose(fid);
    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)

  5. #5
    Rédacteur

    Homme Profil pro
    Comme retraité, des masses
    Inscrit en
    Avril 2007
    Messages
    2 978
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 83
    Localisation : Suisse

    Informations professionnelles :
    Activité : Comme retraité, des masses
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 2 978
    Points : 5 179
    Points
    5 179
    Par défaut
    Salut!
    Il y a une solution très simple: tu écris un autre programme qui lit tes données comme elles sont sur un fichier et les transcrit sur un autre fichier dans un format compatible avec Matlab. Ce programme peut être soit écrit dans un langage de programmation comme le Fortran ou le C, soit une macro dans un logiciel de traitement de texte ou un éditeur.
    Jean-Marc Blanc
    Calcul numérique de processus industriels
    Formation, conseil, développement

    Point n'est besoin d'espérer pour entreprendre, ni de réussir pour persévérer. (Guillaume le Taiseux)

  6. #6
    Futur Membre du Club
    Inscrit en
    Avril 2012
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Merci pour votre aide.
    En particulier Dut, ta fonction est légèrement plus rapide qu' un strrep.

    Ce que j'ai fait c'est que je crée un fichier texte pour savoir quels fichiers ont des . et lesquels ont des ,. Ce fichier permet de garder une mêmoire des fichiers déjà convertis ou de ceux qu'il reste à convertir.

    Bonne journée à tous, problème résolu ... à moins que quelqu'un connaisse comment changer le séparateur décimal de MAT, ce qui doit être possile à mon sens.

Discussions similaires

  1. Lire dans un fichier dans différents formats
    Par benobab dans le forum C#
    Réponses: 3
    Dernier message: 01/09/2014, 16h39
  2. [PHP 5.2] Nombre de connexions simultanées avec les mêmes identifiants
    Par Invité dans le forum Langage
    Réponses: 3
    Dernier message: 20/02/2012, 14h39
  3. [Crystal Report] Nombre de copies différentes
    Par franck.cvitrans dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 25/11/2004, 11h09
  4. URGENT - Nombre d'enregistrements différents dans une table
    Par Jeankiki dans le forum Bases de données
    Réponses: 6
    Dernier message: 11/08/2004, 15h51
  5. UNION de deux SELECT avec nombre d'arguments différents
    Par orus8 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 16/07/2004, 14h32

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