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 :

Récupération de données [Débutant]


Sujet :

MATLAB

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut Récupération de données
    Bonjour, pour commencer je suis une jeune étudiant en informatique et je débute tout juste sur MatLab.

    Dans le cadre d'un projet je dois , sur Matlab, récupérer certaines données dans un fichier excel. Dans une certaine colonne je doit isoler tout les identifiants commençant par 'BEA' et récupérer les lignes correspondant à ces dernier. Après avoir cherché je ne trouve pas de solution , ou j'ai mal cherché ce qui est possible. Je peux ouvrir le fichier excel, écrire dedans mais pour récupérer qu'une partie alors la...
    Biensur je ne demande pas une solution mais une petite piste pour pouvoir de Matlab ne récuper que certaines lignes.

    Merci d'avance et bonne journée !

  2. #2
    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
    Bonjour,

    Une petite piste pour débuter: regarde du côté de csvread
    Le plus simple étant de récupérer ce qui t'intéresse dans ton fichier excel et ensuite de mettre en place un filtre pour isoler tout les identifiants commençant par 'BEA'.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut Types
    Bonjour, d'abord merci pour la piste

    Le problème est, que d’après ce que j'ai pu comprendre et voir, csvread ne prend en compte que les numérique et du coup il n'a pas l'air d'aimer que mon tableau mélange des caractères et du numérique

    Ou a moins qu'il y a possibilité de détourner la chose. J'ai vu que textscan était pas mal pour mon problème mais il faut un fichier txt, y a t'il possibilité de changer les données d'un fichier excel en un fichier txt et après avoir récupérer ce qui m’intéresse les ré-écrire dans un nouveau fichier excel ?

    Je l'avoue je suis totalement bloqué, c'est un peu mon seul espoir

  4. #4
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 883
    Points : 3 433
    Points
    3 433
    Par défaut
    xlsread sera plus adapté

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut xlsread
    Bonjour, merci pour la rapidité !

    Donc je me suis renseigné sur ce xlsread mais après avoir lu le fichier excel qu'est ce que je peux faire de plus ? Il n'existe donc aucune fonction sur MatLab permettant d'isoler des lignes comportant certains caractères

    Je m'excuse d'avance si mes questions peuvent paraître bêtes mais je découvre Matlab et je débute en informatique.

  6. #6
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 883
    Points : 3 433
    Points
    3 433
    Par défaut
    bah si
    utilise la syntaxe complete de xlsread (au niveau des sorties) et tu aura 3 matrices, une avec que les texte, une avec que les chiffres et une avec tout (raw)
    il te suffit de filtrer cette matrice en utilisant des fonctions comme findstr et l'indexage logique

  7. #7
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut xlsread
    Oui c'est vrais j'ai pas pensé à faire comme ça...
    Donc j'ai mes matrices mais j'ai un petit problème sur mon strfind.
    Il me retourne rien. Donc le strfind va directement chercher dans les matrices ou alors je dois enregistrer la matrice voulu (et je ne sais pas trop comment faire mon save n'a pas l'air de vouloir marcher) et faire le strfind sur cette matrice ?

    En tout merci pour les infos, première fois que je vais chercher de l'aide sur un forum et je suis pas déçu !

  8. #8
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 883
    Points : 3 433
    Points
    3 433
    Par défaut
    un truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    [~,~,raw] = xlsread(monfichier);
    [row,col] = find(strcmp(raw,'monstring'));

  9. #9
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    Merci, j'avais aussi trouvé quelque chose de similaire mais le soucis c'est que le 'BEA' que je cherche est suivi de 2 numériques ( BEA01, BEA02...BEA06). Donc si je met juste BEA il ne trouve rien. Y a t-il possibilité sur Matlab de faire comprendre que c'est tout ce qui commence par BEA et que le reste peut etre n'importe quoi ?

    Sinon je crée plusieurs matrice (row1, row2... etc) et après je les concatènes ? Mais par contre j'obtiens le numéro des lignes correspondantes mais récupérer les informations des ces lignes j'ai du mal ( l'histoire de changer).

  10. #10
    Invité
    Invité(e)
    Par défaut
    Bonsoir,

    Tu peux utiliser la fonction strncmp à la place.

    Avec l'indexage logique, tu peux récupérer les données BEA*
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    raw( strncmp(raw, 'BEA',3) )
    Ou par simple parcours :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for k = 1:length(row)
        raw{row(k),col(k)}
    end

  11. #11
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    Bonjour !

    Alors merci, d'avoir tout d'un coup ça m'évite de devoir concaténer 6 matrices

    Mais du coup j'avais commencé a tester, avec les deux matrices de résultats que j'avais, pour récupérer les informations de chaque lignes de chaque identifiant 'BEA'. Enfin je vais expliquer le contexte ça sera plus simple, en bref je dois récupérer les lignes ou les locaux on un identifiant commençant pas 'BEA' pour en suite créer une interface graphique d'un emploi du temps (mais ça je verrai plus tard !). Donc j'ai essayé de bidouiller hier pour récupéré les information de chaque lignes mais ça tout 'cassé' plus que autre chose. Matlab a une fonctionnalité pour passer d'une matrice a un .xls ou il faut lire une matrice et en suite faire un writexls ?

    Mais en tout cas encore merci !

  12. #12
    Invité
    Invité(e)
    Par défaut
    On va alors rester sur ma première solution :
    on commence par récupérer notre tableau logique de même taille que raw (1 pour BEA*, 0 sinon)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    isBEA = strncmp(raw, 'BEA',3);
    On utilise la fonction any sur la deuxième dimension pour savoir s'il y a au moins un '1' logique sur chaque ligne de isBEA :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    isBEA_rows = any(isBEA, 2);
    Et on l'applique sur notre raw d'origine pour récupérer nos lignes contenant au moins un BEA*
    Pour l'écriture, tu peux directement utiliser la fonction xlswrite, voir FAQ Comment interfacer MATLAB avec Excel ?

  13. #13
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    Alors ça marche parfaitement, sauf un petit truck qui est une erreur de ma part.
    Je n'avais pas vu que certaine cellule était composées de plusieurs locaux.
    Par exemple quand y a : "BEA06/BEA14" ça marche bien
    Mais quand c'est : "B4008/B4016/B4022/C4008/C4016/D3020/D4022/BEA03" Il ne les prends pas en comptes.

  14. #14
    Invité
    Invité(e)
    Par défaut
    Effectivement car strncmp ne vérifie que les trois premiers, soit ici
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    B4008/B4016/B4022/C4008/C4016/D3020/D4022/BEA03
    On va donc réutiliser strfind dans ce cas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    isBEA =  ~cellfun(@isempty, strfind(raw,'BEA'));

  15. #15
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    A oui autant pour moi !
    J'ai un jolie message d'erreur :
    Error using cell.strfind
    Too many input arguments.
    
    Error in test_connect (line 8)
    isBEA = ~cellfun(@isempty, strfind(raw, 'BEA'));
    Il n'a pas l'air d'aimer le strfind qu'il y a dedans

  16. #16
    Invité
    Invité(e)
    Par défaut
    On va rentrer strfind dans cellfun alors
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    isBEA = ~cellfun(@(str) isempty(strfind(str,'BEA')), raw);

  17. #17
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    ça a l'air si simple

    Et bien ça marche parfaitement ! Je n'est plus qu'a faire le trie de certaine colonnes, mettre des titres pour chacune et ça sera nickel . Juste pour être sur pour la 'restriction' de mes colonnes c'est quelque chose du genre: ans(:,9) si je veux la colonne 9 par exemple ?.

    En tout cas mille mercis pour cette aide précieuse !

  18. #18
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Seriale Voir le message
    ça a l'air si simple
    Ça l'est
    Citation Envoyé par Seriale Voir le message
    Juste pour être sur pour la 'restriction' de mes colonnes c'est quelque chose du genre: ans(:,9) si je veux la colonne 9 par exemple ?.
    C'est bien cela, : indique que tu prends tous les éléments de la première dimension, et 9 que tu sélectionnes la 9ème colonne.

  19. #19
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    Oui avec un peu d'entrainement je n'en doute pas mais j'ai appris l'existence de Matlab que depuis 4 jours . Après deux mois de stage ça devrai aller mieux !

    D'accord je verrai tout ça demain

  20. #20
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 34
    Points : 21
    Points
    21
    Par défaut
    Désoler pour cette énieme modification du message
    "Alors en fait j'ai encore un problème

    Donc j'ai ma matrice avec juste les lignes que je veux. Mais paris ce tableau il me faut que 3 colonnes. Je peux les récupérer une par une les sauvegarder et après faire un load dans mon code mais c'est la que je me rend compte que en fait non... Il faut que mon application ne soit pas statique. Donc il faut que j'automatise la création de ces matrices. Je sais pas si c'est claire donc pour faire simple : d'une matrice je dois récupérer juste 3 colonnes et de façon dynamique. "

    Donc j'ai résolu le problème en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    mat_classe=ans(:,4);
    mat_locaux=ans(:,9);
    mat_profs=ans(:,11);
    mat_CPL=[mat_profs,mat_classe,mat_locaux];
    Mais il me souligne "ans" en me disant que c'est pas recommandé de l'utiser mais je peux pas faire autrement. Mis a part ça je pense que sa marche bien

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 4
    Dernier message: 05/04/2004, 10h09
  2. Réponses: 2
    Dernier message: 20/02/2004, 08h47
  3. [ DB2] => [ORACLE] Récupération de données
    Par LeDid dans le forum DB2
    Réponses: 3
    Dernier message: 25/06/2003, 17h10
  4. Réponses: 13
    Dernier message: 20/03/2003, 08h11
  5. [XMLRAD] récupération de donnée
    Par Mitch79 dans le forum XMLRAD
    Réponses: 7
    Dernier message: 30/01/2003, 15h36

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