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

Langage Java Discussion :

Ouvrir un fichier dont la fin du nom change via regex?


Sujet :

Langage Java

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut Ouvrir un fichier dont la fin du nom change via regex?
    Bonjour,

    Je développe une application qui doit ouvrir un fichier xls sur un des disques du PC. Le nom du fichier est "STOCK KARDEX ECT +une date". Le problème est donc que mon fichier va changer régulièrement, mais les suivants auront toujours ce même schéma. J'ai donc penser à une regex.
    J'utilise l'api jxl, car ce sont des fichiers Excel.

    Donc par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Workbook unWorkbook = Workbook.getWorkbook(fichier);
    avec fichier qui doit être de type String.

    Je ne vois pas comment faire car le chemin ne pas etre saisi par l'utilisateur, une chose du genre if(saisiParUtil.matches("STOCK KARDEX ECT"+"*")) ... n'est pas interessante pour moi.

    Merci

  2. #2
    En attente de confirmation mail
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Octobre 2010
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 501
    Points : 1 060
    Points
    1 060
    Par défaut
    Bonjour,

    Pour ça, il est possible d'utiliser FilenameFilter:

    http://download.oracle.com/javase/6/...ilenameFilter)

    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    File directory = null;
    // (...) initialisation de directory
    directory.list(new FilenameFilter() {
    	@Override
    	public boolean accept(File dir, String name) {
    		return (name.startsWith("STOCK KARDEX ECT"));
    	}
    });

  3. #3
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    Merci Nudger de ton aide. Par contre dans ton code tu te sers d'une variable de type File or (et je remarque que ma ligne de code est incomplète)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Workbook workbook = Workbook.getWorkbook(new File(fichier));
    fichier ici doit bien être de type String.

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    Obtenir un chemin à partir d'un nom de fichier, ca ne pose aucun problème, suffit de lire la doc de File

    De plus, dans le code que vous mettez, vous utilisez bien un File, donc je vois pas où est le soucis.

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    Je ne veux récupérer aucun chemin, je l'ai déjà. Par contre j'utilise déjà un file en effet. Mais il manque quelque chose dans cet exemple non?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
                directory.list(new FilenameFilter() {
                    @Override
                    public boolean accept(File dir, String name) {
                        return (name.startsWith("STOCK KARDEX ECT"));
                    }
                });
    On n'utilise ni la variable dir ni name . Et tel quel j'ai une NullPointerException

  6. #6
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    oui il manque le stockage de la valeur de retour de la méthode list
    Suffit de le stocker et de l'exploiter

  7. #7
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    Même erreur avec:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
                String[] listeS = directory.list(new FilenameFilter() {
                    @Override
                    public boolean accept(File dir, String name) {
                        return (name.startsWith("STOCK KARDEX ECT"));
                    }
                });

  8. #8
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    on peux voir votre code et l'excpetion levée. Parce que, dans l'absolu là, ça ne nous dit rien votre erreur.

  9. #9
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
    at interfacegraphique.PanneauAccess$ActionEntrerListener.actionPerformed(PanneauAccess.java:529)

    et à la ligne 529 j'ai ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String[] listeS = directory.list(new FilenameFilter() {
    Ensuite j'essaie de faire passer ma chaine de caractère dans la fonction suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    uneRechercheStockCommande.rechercheStockECT(PN.getText(), listeS[0]);

  10. #10
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    directory est null.

  11. #11
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    Et bien oui j'ai repris le code de Nudger. Comment dois-je l'initialiser?

  12. #12
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    le code de Nudger disait clairement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    File directory = null;
    // (...) initialisation de directory
    Vous devez bien sur mettre dans cette variable le répertoire que vous voulez scanner

  13. #13
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    J'ai deux fichiers Excel au bout du chemin que j'ai spécifié. Or il me met une erreur : java.io.FileNotFoundException: STOCK KARDEX ECT 15-04-2011.xls (Le fichier spécifié est introuvable) alors qu'à priori dans l'erreur il me met le nom d'un des deux fichiers qui existe bel et bien. Donc il arrive à le retrouver à priori. Mais pas à l'ouvrir?!?

  14. #14
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    la méthode lsit va vous retourner le nom relatif des fichiers qui correspondent à votre critère. A vous, après, de construire un object File correctement à partir de ce nom et du directory.

  15. #15
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2010
    Messages
    273
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 273
    Points : 73
    Points
    73
    Par défaut
    merci, ça fonctionne.

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

Discussions similaires

  1. Copier un fichier dont une partie du nom change tous les jours
    Par Hazard17 dans le forum Général VBA
    Réponses: 13
    Dernier message: 22/01/2015, 08h58
  2. Réponses: 11
    Dernier message: 04/06/2014, 14h09
  3. [Batch] Ouvrir un fichier dont le nom est partiellement connu.
    Par TGV6773 dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 03/02/2010, 18h24
  4. [VBS] Ouvrir un fichier dont on ne sait pas le nom
    Par TGV6773 dans le forum VBScript
    Réponses: 3
    Dernier message: 02/02/2010, 16h12
  5. [VBA-E]ouvrir un fichier dont le nom est determiné par sa date de création
    Par olivertwist dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 17/04/2007, 17h29

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