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 :

Fonction pour selection des fichiers en fonction du nom.


Sujet :

MATLAB

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut Fonction pour selection des fichiers en fonction du nom.
    Bonjour,

    Je me permets de vous deamander un peu d'aide, car je ne trouve pas la fonction adequat.

    J'ai un dossier, avec plein de fichier zip.
    Je souhaites que maltlab selectionne dans ce dossier uniquement les fichiers qui on "Mar" dans leur nom.
    Qu'il copie les dossiers extraits et qu'il les mette dans un autre fichier.
    Qu'ensuite pour chaque dossier extrait qu'il récupère l'un des fichier texte de ce dossier et le stocke soit en format matlab soit dans un fichier Excel.

    Pensez-vous premièrement que c'est possible de faire ça avec matlab ? merci d'avance

  2. #2
    Membre confirmé
    Homme Profil pro
    Éternel universitaire
    Inscrit en
    Avril 2012
    Messages
    421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Éternel universitaire

    Informations forums :
    Inscription : Avril 2012
    Messages : 421
    Points : 639
    Points
    639
    Par défaut
    Imaginons que tu stock la liste de tes fichiers comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    list_files=dir(lechemindetondossier)
    Ensuite tu peux vérifier élément par élément s'il contient "Mar" et ajouter une condition pour tes opération
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    for i = 1:numel(list_files)
        if ~isemplty(strfind(list_files(i).name,'Mar'))
                copyfile('source','destination') % copie les fichiers de source vers destination
                % et tout ce que tu veux faire ensuite 
        end
    end
    Ensuite pour ta question
    Qu'ensuite pour chaque dossier extrait qu'il récupère l'un des fichier texte de ce dossier et le stocke soit en format matlab soit dans un fichier Excel.
    Je ne peux pas t'aider puisque je ne connais pas le format exact du fichier à lire, ni le format auquel tu veux écrire (mais il y a eu déjà beaucoup d'autres posts sur ce sujet dans le forum). Penses aussi à la FAQ.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    merci beaucoup je regarde ça.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Merci beaucoup, Je viens de tester ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    %% Script permettant d'aller chercher les fichiers au bon nom, de les déziper, 
    % et de les copier dans un répertoire % 
    Type_dossier = full;  %Choisi le type variables, mettre Paris pour les données de paris, NY pour les données de NYC et full pour les 2 
    list=dir('/Users/Siegelbaum/Desktop/CVA'); % permet de récupérer les fichiers sur matlab mettre le chemin du dossier contenant les fichiers
    list_files = list(4:end,:); %Enlève les 3 premiers objet de la liste qui ne correspondent pas aux documents utilisés 
    for i = 1:numel(list_files)
        if ~isempty(strfind(list_files(i).name,'Type_dossier'))
                copyfile('/Users/Siegelbaum/Desktop/CVA','/Users/Siegelbaum/Desktop/CVA/Matlab') % copie les fichiers de source vers destination
     
        end
    end
    Le problème c'est que dans CVA/Matlab j'ai une infinité de dossier matlab qui se créer.

    l'erreur :

    Error using copyfile
    cp:
    /Users/Siegelbaum/Desktop/CVA/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/Matlab/full_20131213.tar.gz:
    name too long (not copied)

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

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    copyfile('/Users/Siegelbaum/Desktop/CVA','/Users/Siegelbaum/Desktop/CVA/Matlab')
    Ici, tu copies à chaque fois le contenu du dossier CVA dans son sous-dossier Matlab, ce qui crée un sous-dossier Matlab dans Matlab, puis tu recommences...

    Ici, je pense que les guillemets simples sont de trop :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if ~isempty(strfind(list_files(i).name,'Type_dossier'))
    étant donné que tu utilises Type_dossier comme variable plus haut.

    Tu parlais de sélectionner des fichiers qui ont Mar dans leur nom, tu peux faire cela directement avec la fonction dir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    rep = '/Users/Siegelbaum/Desktop/CVA';
    list = dir( fullfile(rep, '*Mar*') );
    'Mar' qui sera à remplacer j'imagine par Type_dossier, soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    list = dir( fullfile(rep, ['*' Type_dossier '*']) );
    Et c'est la liste des fichiers retenus par dir qui sera à recopier je pense :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for i = 1:numel(list)
        source = fullfile(rep, list(i).name);
        destination = fullfile(rep, 'Matlab', list(i).name);
        copyfile(source, destination)
    end

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    tout roule , impeccable merci pour ton aide !!!

    J'ai donc une autre question.


    Si j'ai un fichier type : MAR_20140112.tar.gz
    qu'il contient un fichier : NOMFICHIER

    Je souhaiterais que mon fichier : "NOMFICHIER" soit copier, coller dans un autre dossier et qu'il s'appel 20140112.

    Donc pour renommer et copier-coller ça va, mais pour extraire les chiffres du nom du ne sais pas comment le faire.

    Merci

  7. #7
    Invité
    Invité(e)
    Par défaut
    Tu peux extraire la date avec la fonction sscanf :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nom_fichier = 'MAR_20140112.tar.gz';
    date_fichier = sscanf(nom_fichier , 'MAR_%8c.tar.gz')

  8. #8
    Membre confirmé
    Homme Profil pro
    Éternel universitaire
    Inscrit en
    Avril 2012
    Messages
    421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Éternel universitaire

    Informations forums :
    Inscription : Avril 2012
    Messages : 421
    Points : 639
    Points
    639
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    list = dir( fullfile(rep, '*Mar*') );
    Y'a toujours quelqu'un qui propose une solution bien plus esthétique que la mienne... Un jour je l'aurai !

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Citation Envoyé par Winjerome Voir le message
    Tu peux extraire la date avec la fonction sscanf :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nom_fichier = 'MAR_20140112.tar.gz';
    date_fichier = sscanf(nom_fichier , 'MAR_%8c.tar.gz')
    merci beaucoup, mais le problème c'est que le nom du fichier c'est plutot :

    type_dossier = 'Full' % L'utilisateur choisi Full, Mar, NY
    et le nom ne sera alors pas fixe mais sera plutôt :

    type_dossier_20140112.tar.gz

    donc il y'a des dossiers qui seront :

    Full_20140112.tar.gz
    NY_20140112.tar.gz
    Mar__20140112.tar.gz

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nom_fichier = 'MAR_20140112.tar.gz';
    date_fichier = sscanf(nom_fichier , 'MAR_%8c.tar.gz')
    Donc quand je mets : 'MAR_%8c.tar.gz' ça ne peut pas être fixe ?!

    Je ne sais pas si je suis clair.

    Merci beaucoup

  10. #10
    Invité
    Invité(e)
    Par défaut
    Il suffit d'utiliser type_dossier comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    date_fichier = sscanf(nom_fichier , [type_dossier '_%8c.tar.gz'])

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    mille merci j'avais fait en galèrant avec une boucle if ! mais ta méthode est 10 fois plus rapide

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Je me permet de revenir vers vous.

    Alors maintenant j'ai mon fichier qui se trouve dans ce chemin, son nom est 20131213

    /Users/Siegelbaum/Desktop/Expofini/20131213

    Dans le dossier Expofini, il y'a plein de fichier avec des dates différentes. Ce sont des fichiers texte qui n'ont pas d'extension et utilisent comme délimiteur : "@"

    Je souhaite que l'utilisateur puisse entre une date, lancer le script et que cela charge automatiquement le fichier dans le workspace.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    date_expo = 20131213; %L'utilisateur entre la date de l'exposition souhaitée 
    delimiterIn = '@'; %Delimiteur des séries d'exposition 
    repertoire3 = '/Users/Siegelbaum/Desktop/Expofini/';
    chemin6=fullfile(repertoire3, date_expo); %permet de créer un chemin qui change en fonction de la date d'expo
    A= importdata(chemin6, delimiterIn);
    Le problème, c'est que j'ai ça :

    Error using importdata (line 136)
    Unable to open file.


    Je me demande si l'erreur ne vient pas du fichier qui est sans extension. Mais quand j'essaye de l'ouvrir à la main pas de problème.

    Merci pour votre aide

  13. #13
    Invité
    Invité(e)
    Par défaut

    Si tu dois manipuler des valeurs numériques, puis les passer en chaines de caractères, utilise la fonction sprintf. (Cf la FAQ Comment effectuer la concaténation chaîne de caractères - valeurs numériques ?)

  14. #14
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Merci ça passe en renomant en .txt

  15. #15
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Vous savez comment je peux faire pour la fonction dir ne prenne pas dans list des valeurs '.' et '..' car je crée un nouvel liste en lui disant de faire sauter les 3 premières valeurs, ça fonctionne mais ce n'est pas très esthétique.

    Merci pour votre aide

  16. #16
    Invité
    Invité(e)
    Par défaut
    Avec list = dir( fullfile(rep, ['*' type_dossier '*']) ); tu ne devrais pas récupérer ces éléments.

    Sinon tu peux les supprimer en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    list( strncmp({list.name}, '.', 1) ) = [];

  17. #17
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Non non parfait avec le type_dossier.

    Mais c'est des zip ... une fois que je les extraits, je dois aller chercher les fichiers dedans et refaire une list et là j'ai ce problème.

    je teste ta technique.

  18. #18
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 200
    Points : 46
    Points
    46
    Par défaut
    Je crie au génie !

    Encore une chose.

    Imaginons :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Variable = '20131412' ; 
    delimiterIn = '@'; 
    chemin = fullfile(repertoire, 20131412') 
    Variable = importdata(chemin, delimierIN)
    ça ne fonctionne pas. En fait, quand je donne une date, la variable chemin vas chercher le fichier de date, et il l'importe, je voudrais qu'en l'important il garde le nom de la date.

  19. #19
    Invité
    Invité(e)
    Par défaut
    Qu'entends-tu par
    Citation Envoyé par diego45
    je voudrais qu'en l'important il garde le nom de la date.
    ?
    Attention à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    >> class(20131412')
    
    ans =
    
    double
    
    >> class('20131412')
    
    ans =
    
    char

Discussions similaires

  1. Fonction pour lire des fichiers dans une archive MPQ
    Par MegaBigBoss dans le forum Débuter
    Réponses: 0
    Dernier message: 28/01/2012, 22h02
  2. fonction pour ouvrir des fichiers
    Par ashley dans le forum C
    Réponses: 8
    Dernier message: 26/08/2009, 16h55
  3. Fonction récursive pour traitement des fichiers
    Par Montor dans le forum Contribuez
    Réponses: 6
    Dernier message: 29/09/2008, 07h45
  4. Réponses: 1
    Dernier message: 10/09/2006, 16h09
  5. Réponses: 10
    Dernier message: 03/07/2006, 11h32

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