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

Macros et VBA Excel Discussion :

Récupérer l'emplacement d'un csv


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2018
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2018
    Messages : 12
    Par défaut Récupérer l'emplacement d'un csv
    Bonjour

    Je voudrais récupérer l'emplacement d'un csv.

    Pour cela j'utilise :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
            Chemin = objFolder.ParentFolder.ParseName(objFolder.Title).Path & ""
    Qui marche très bien pour un fichier Excel mais pas pour un fichier csv.

    Qu'est ce que je doit modifier ?

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Quelles sont tes données de base ? Un classeur ouvert ?
    Si c'est le cas, il est plus simple de passer par ActiveWorkbook.Path.

  3. #3
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2018
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2018
    Messages : 12
    Par défaut
    Je veux justement l'emplacement pour pouvoir le mettre dans une variable et ouvrir le fichier avec opentext.

  4. #4
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Je repose la question : quelles sont les données de base ?
    Tu recherches le fichier par son type sur l'intégralité du disque sans connaitre son nom ?

  5. #5
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2018
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2018
    Messages : 12
    Par défaut
    J'utilise ce code pour ouvrir une boite de dialogue qui propose à l'utilisateur d'aller chercher le fichier.

    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    'Constantes permettant de personnaliser le fonctionnement de BrowseForFolder
    Const BIF_RETURNONLYFSDIRS = &H1 'pour chercher les fichiers systèmes seulement
                                        ' si le dossier sélectionné ne contient pas
                                        ' de fichier système alors le bouton "OK" est grisé
    Const BIF_DONTGOBELOWDOMAIN = &H2 'interdit d'explorer en dehors du domaine 'For starting the Find Computer
    Const BIF_STATUSTEXT = &H4 '
    Const BIF_RETURNFSANCESTORS = &H8 'seulement des dossiers
    Const BIF_EDITBOX = &H10 'Affiche une zone d'édition
    Const BIF_VALIDATE = &H20 'Vérifie la saisie dans la zone d'édition
    Const BIF_BROWSEFORCOMPUTER = &H1000 'Autorise le parcours réseau
    Const BIF_BROWSEFORPRINTER = &H2000 'mes documents et bureau uniquemnet
    Const BIF_BROWSEINCLUDEFILES = &H4000 'dossiers et fichiers
    Const BIF_NONEWFOLDERBUTTON = &H200 'ne pas mettre le bouton Nouveau dossier
     
    'affiche la boite de dialogue Windows de recherche d'un dossier
     
    Function ChoixDossierFichier(bDos As Boolean, Msg As String) As String
    'bDos 0 sélection de fichier ; 1 sélection de dossier
    'Msg Message affiché sur la boite
     
        Dim objShell As Object, objFolder As Object
        Dim Chemin As String
        Dim FlagChoix As Long, NbPoint As Integer
     
        If bDos Then
          FlagChoix = BIF_RETURNFSANCESTORS
        Else
          FlagChoix = BIF_BROWSEINCLUDEFILES + BIF_NONEWFOLDERBUTTON
        End If
     
        Set objShell = CreateObject("Shell.Application")
    ' 1er paramètre toujours 0 (zéro). Il représente le handle de la fenêtre parent
    ' 2ème paramètre Titre de la boite, en dessous de la barre de titre
    ' 3ème paramètre options de BrowseForFolder
    ' 4ème paramètre Facultatif. Répertoire de début d'exploration
        On Error Resume Next
        Set objFolder = objShell.BrowseForFolder(&H0&, Msg, FlagChoix)
        'Si l 'objet retourné est valide, on teste son contenu (item.title)
        'Si on a sélectionné la racine d'une partition, il se compose du nom de la partition,
        ' suivi de sa lettre et ":" entre parenthèses
        NbPoint = InStr(objFolder.Title, ":")
        If NbPoint = 0 Then
            'Sinon, il se compose du nom du dossier uniquement, sans le chemin précédent
            'On récupère ce chemin à l'aide des propriété et méthode ParentFolder.ParseName
            Chemin = objFolder.ParentFolder.ParseName(objFolder.Title).Path & ""
        Else
            ' si racine on récupère la lettre du lecteur et les 2 points
            Chemin = Mid(objFolder.Title, NbPoint - 1, 2)
        End If
        ChoixDossierFichier = Chemin
    End Function
    Puis j'ouvre le fichier avec ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim WbExtract As Workbook
    gstrNomFichierExtract = ChoixDossierFichier(0, "Choisissez le fichier Audittab :")
     Workbooks.OpenText Filename:=gstrNomFichierExtract, Origin:=xlWindows, _
            StartRow:=1, DataType:=xlDelimited, Local:=True, Semicolon:=True
    Set WbExtract = ActiveWorkbook
    Malheureusement la variable gstrNomFichierExtract est vide si je choisi un CSV, alors que pour un fichier Excel la variable contient l'emplacement du fichier.

  6. #6
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Commence par supprimer le On Error Resume Next histoire de ne pas travailler dans le brouillard.
    Fais avancer le programme en pas-à-pas et surveille le contenu de la variable ObjFolder.

Discussions similaires

  1. Réponses: 7
    Dernier message: 12/04/2010, 16h47
  2. Récupérer l'emplacement d'un fichier sur le pc du visiteur
    Par Araminas dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 22/06/2009, 07h17
  3. Récupérer l'emplacement du dossier IIS
    Par soso78 dans le forum ASP.NET
    Réponses: 2
    Dernier message: 03/04/2008, 11h42
  4. [VB.NET]récupérer l'emplacement d'un fichier sur \c:
    Par zouhib dans le forum Windows Forms
    Réponses: 20
    Dernier message: 17/05/2006, 11h26

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