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 :

Problème de nombre de colonnes


Sujet :

MATLAB

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut Problème de nombre de colonnes
    Bonjour,
    je dois traiter des données journalières et horaires (disposition : date - heure -valeur ) mais une fois mon fichier chargé, MATLAB ne considère qu'une seule colonne. J'ai essayé différents formats, je ne m'en sors pas. Donc si vous aviez une solution ou des pistes (j'ai 2927 lignes au total):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
        '07/10/2000 00:00:00	1.01'
        '07/10/2000 01:00:00	0.955'
        '07/10/2000 02:00:00	0.91'
        '07/10/2000 03:00:00	0.882'
        '07/10/2000 04:00:00	0.927'
        '07/10/2000 05:00:00	0.871'
        '07/10/2000 06:00:00	0.94'
     
    >> size (A)
     
    ans =
     
            2927           1

  2. #2
    Membre habitué
    Homme Profil pro
    Ingénieur opto-électronique
    Inscrit en
    Avril 2010
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur opto-électronique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2010
    Messages : 129
    Points : 157
    Points
    157
    Par défaut
    Ce fichier que tu charges est sous quel format ? .txt ?
    En tout cas, la fonction textscan devrait t'aider.

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Oui il est en.txt. J'ai essayé avec TEXTSCAN mais je bloque au niveau de l'entrée des données de format. J'ai eu trop de messages d'erreurs différents

  4. #4
    Membre habitué
    Homme Profil pro
    Ingénieur opto-électronique
    Inscrit en
    Avril 2010
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur opto-électronique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2010
    Messages : 129
    Points : 157
    Points
    157
    Par défaut
    Quelque chose comme ça devrait marcher:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    fid=fopen('monfichier')
    donnees=textscan(fid, '%s %s %d');
    En faisant ceci, tu enregistres tes données dans la variable "donnee" qui sera un tableau de cellules. donnees{1} te donneras les dates (type string), donnees{2} les heures (type string) et donnees{3} tes valeurs (type double).

    Le délimteur par défaut est l'espace, il est possible que tu aies à le modifier, l'aide te dira comment faire si c'est le cas =)

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

    La solution avec textread:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    [Dates Heures Donnees] = textread('monfichier.txt','%s %s %f');
    % Ou
    [jj mm aaaa hh mn ss Donnees] = textread('monfichier.txt','%d/%d/%d %d:%d:%d %f')

  6. #6
    Expert confirmé
    Avatar de duf42
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Novembre 2007
    Messages
    3 111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Formateur en informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 111
    Points : 4 661
    Points
    4 661
    Par défaut
    Bonjour,

    La fonction TEXTSCAN doit être privilégiée par rapport à TEXTREAD car cette dernière ne sera bientôt plus supportée (reste à savoir quand)

    Duf
    Simulink & Embedded Coder

    Au boulot : Windows 7 , MATLAB r2016b
    A la maison : ArchLinux mais pas MATLAB

  7. #7
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Merci à tous pour ces infos, et pour le super boulot fait sur ce forum

  8. #8
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Par contre j'ai désormais un souçi pour convertir mes données (cell array) en double array, de part le présence des dates :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    [FileName,PathName] = uigetfile('*.txt','Multiselect','on');
     
    fid=fopen(fullfile(PathName,FileName),'r');
    A = textscan(fid, '%s %s %s %s %f32');
    fclose(fid);
    B = str2double(A)
     
    B =
     
       NaN   NaN   NaN   NaN   NaN
    Comment faire pour disposer de données exploitables sous Matlab ?

  9. #9
    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
    Le format que tu utilises avec TEXTSCAN ne correspond pas aux données contenues dans ton fichier.

    Le format %s sert à spécifier une chaine de caractères délimitée par un (ou des) espace(s).

    Donc d'après ton premier message, chaque ligne contient 2 chaines de caractères (%s) puis une valeur réelle (%f) => '%s%s%f'

    D'ailleurs où as-tu trouvé le format %f32 ?
    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)

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 640
    Points : 776
    Points
    776
    Par défaut
    Salut,

    Il suffit d'utiliser aussi cell2mat.

    en gros, tu transformes ta cellule en chaine de caractères puis les caractères en valeures.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    help cell2mat
    help str2num
    help str2double
    Pour ton code, perso j'utiliserais deux %s puisque la séparation n'est pas identique. Je ferais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    A=textscan(fid,'%s %s','delimiter','\t')
     
    dateheure=cell2mat(A{1});
    data=str2double(cell2mat(A{2}))
    Tu as tes données en double. Et la date et heure dans un vecteur. T'as plus qu'à choisir ensuite quelle partie tu souhaites.

  11. #11
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    J'ai trouvé le format %f32 dans l'aide de Matlab. Bon bah la c'est le top, je n'arrive même plus à réouvrir mes fichiers texte (en gros je n'obtiens plus la même chose qu'hier en ouvrant la même fonction ).
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    >> fid=fopen('H2000.txt');
    A = textscan(fid, '%s %s  %f32');
    >> A
     
    A = 
     
        {1x1 cell}    {1x1 cell}    [0x1 single]
    Sachant que les fichiers que j'ouvre sont sous cette forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    01/09/2000 01:00	 0.375
    01/09/2000 02:00	 0.36
    01/09/2000 03:00	 0.35
    01/09/2000 04:00	 0.35
    01/09/2000 05:00	 0.35
    01/09/2000 06:00	 0.35
    01/09/2000 07:00	 0.35
    01/09/2000 08:00	 0.35
    01/09/2000 09:00 0.35
    01/09/2000 10:00 0.35
    01/09/2000 11:00	 0.35
    01/09/2000 12:00	 0.35
    01/09/2000 13:00	 0.35
    (la colonne est alignée normalement, ya pas d'soucis)

    Par contre j'obtiens en ajoutant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    fid=fopen('H2001.txt')
    A=textscan(fid,'%s %s','delimiter','\t')
     
    dateheure=cell2mat(A{1});
    data=str2double(cell2mat(A{2}))
    la réaction épidermique suivante
    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
     
    fid =
     
        12
     
     
    A = 
     
        {2927x1 cell}    {2927x1 cell}
     
     
    data =
     
       NaN
     
    >> dateheure
     
    dateheure =
     
    ÿþ0

  12. #12
    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
    Citation Envoyé par TomAlbus Voir le message
    J'ai trouvé le format %f32 dans l'aide de Matlab
    Ah oui, effectivement dans l'aide de TEXTSCAN...

    Sinon le code fonctionne bien sur ma machine :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    A = 
     
        {13x1 cell}    {13x1 cell}    [13x1 single]
    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)

  13. #13
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2011
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    BOn au final j'ai réussi à m'en sortir en faisant ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    fid=fopen('H2000tab.txt');
    A=textscan(fid,'%10c %5c %f');
     
    At = datestr (A{2});% date et heure
    Av = A{3};% données
     
    Ad = datestr (A{1});%date seule

Discussions similaires

  1. [2008R2] Problème de nombre de colonnes dans une matrice
    Par cana13 dans le forum SSRS
    Réponses: 5
    Dernier message: 17/11/2011, 11h51
  2. [AC-2007] analyse croisé, problème nombres de colonnes.
    Par djas_air dans le forum IHM
    Réponses: 3
    Dernier message: 01/06/2011, 19h33
  3. Problème recherche nombre dans colonne
    Par kanabzh29 dans le forum Excel
    Réponses: 10
    Dernier message: 25/09/2008, 13h33
  4. [JTextArea]changer dynamiquement le nombre de colonnes
    Par MrDuChnok dans le forum Composants
    Réponses: 9
    Dernier message: 27/04/2004, 13h31
  5. [RDB$PRIMARY] Nombre de colonnes
    Par Lucien dans le forum InterBase
    Réponses: 4
    Dernier message: 17/01/2004, 12h55

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