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

Scilab Discussion :

Traitement par lot des fichiers d'un répertoire (listing) [Débutant]


Sujet :

Scilab

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Mars 2010
    Messages : 48
    Points : 33
    Points
    33
    Par défaut Traitement par lot des fichiers d'un répertoire (listing)
    Bonjour à tous,

    débutant dans scilab je bloque sur une fonction visiblement evoquée plusieurs fois mais que je n'arrive pas à valider.
    J'ai un répertoire avec plusieurs (beaucoup) de fichier CSV.
    J'ai une fonction qui traite un fichier CSV avec un paramètre en dur qui est le nom d'un fichier.
    Je veux la lancer la fonciton pour l'ensemble des fichiers

    Le traitement:
    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
    21
    22
     
    rep= "C:\TEMP\";
    LON=csvRead(rep+"\_Mapping\LON.csv");
    LAT=csvRead(rep+"\_Mapping\LAT.csv");
    substitute = [
    "NaN" "-9999"
    ];
    for i=1
    end
    ET=csvRead(rep+"reference_ET_PenmanMonteith20100308.csv",[],[],[],substitute);
    xyz=zeros(289*752,3);
    k=0;
    for i=1:201,
    for j=1:300,
    k=k+1;
    xyz(k,1)=LAT(i,j);
    xyz(k,2)=LON(i,j);
    xyz(k,3)=ET(i,j);
    end
    end
    comments = ["Lat;Long;ET0"];
    csvWrite(xyz, rep+"_Mapping\XYZ\xyz.csv",";",",",[],comments)
    Je cherche donc à traiter tous les fichiers CSV (nom du fichier test reference_ET_PenmanMonteith20100308.csv) d'un répertoire.
    J'ai réussi à les lister mais pas utiliser cette liste comme paramètre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ext = "*.csv";
    chemin= fullfile("C:\TEMP",ext);
    list = dir(chemin);
    Merci d'avance pour ceux qui pourront m'aider.

  2. #2
    Nouveau membre du Club
    Inscrit en
    Mars 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Mars 2010
    Messages : 48
    Points : 33
    Points
    33
    Par défaut
    Je pense avoir avancé
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    //listing des fichiers
    ext = "*.csv";
    chemin= fullfile("monchemin",ext);
    list = dir(chemin);
    nbfic=size(list.name,1);
    //définition des variable
    rep= "monchemin";
    LON=csvRead(rep+"\_Mapping\LON.csv");
    LAT=csvRead(rep+"\_Mapping\LAT.csv");
    substitute = [
    "NaN" "-9999"
    ];
     
    //boucle sur tous les fichiers listés
    for fic=1:nbfic
        //lecture du fichier
        ET=csvRead(list.name(fic),[],[],[],substitute);
        //initialisation de la matrice
        xyz=zeros(289*752,3);
        //Insertion des données
        k=0;
        for i=1:201,
            for j=1:300,
                k=k+1;
                xyz(k,1)=LAT(i,j);
                xyz(k,2)=LON(i,j);
                xyz(k,3)=ET(i,j);
            end
        end
        comments = ["Lat;Long;ET0"];
        csvWrite(xyz, rep+"_Mapping\XYZ\"+fic+".csv",";",",",[],comments)
    end
    Je ne vois pas d’où vient l'erreur...
    Merci

    EDIT
    c'est bon, c'était un problème de chemin!

  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 : 53 163
    Points
    53 163
    Par défaut
    Continue à utiliser fullfile dans ton code.

    Remplace :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rep+"_Mapping\XYZ\"+fic+".csv"
    par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    fullfile(rep, "_Mapping", "XYZ", fic+".csv")
    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)

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 20/02/2017, 04h47
  2. Traitement par lot fichiers PDF
    Par Triton972 dans le forum Imagerie
    Réponses: 1
    Dernier message: 10/01/2012, 15h18
  3. Traitement des fichiers d'un répertoire
    Par nansima2011 dans le forum Langage
    Réponses: 1
    Dernier message: 08/03/2011, 14h13
  4. Classement des fichiers d'un répertoire par date
    Par lunick dans le forum Langage
    Réponses: 1
    Dernier message: 16/06/2008, 14h22
  5. Traitement en série des fichiers d'un répertoire
    Par potili2 dans le forum Delphi
    Réponses: 5
    Dernier message: 27/02/2007, 13h33

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