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 :

Importer un CSV distant dans une Feuille


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    676
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 676
    Par défaut Importer un CSV distant dans une Feuille
    Bonjour,

    J'ai un CSV de 500 000 lignes et je souhaite qu'une macro l'importe dans la feuille "Journal". Je ne peux pas trop faire de bidouille du genre "on prend le CSV en local et ensuite on l'ouvre" parce que c'est pour des utilisateurs très lambda qui doivent faire du clic bouton. J'aimerais aussi éviter (si c'est possible) de créer un fichier intermédiaire avec la macro. J'avais trouvé ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    sCSVLink = "http://:@monsite.com/journal.csv"
     
    Set wnd = ActiveWindow
    Application.ScreenUpdating = False
    Sheets("Journal").Cells.ClearContents
    Workbooks.Open Filename:=sCSVLink
    ActiveSheet.Cells.Copy 'Bug !!!
    wnd.Activate
    Sheets("Journal").Paste
    Application.DisplayAlerts = False
    Windows(sfile).Close False
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    Mais ça bug parce qu'il y a trop de ligne pour faire un copier coller. Je sèche un peu sur mon problème j'avoue

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    676
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 676
    Par défaut
    Alors j'ai trouvé :
    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
     
        With ActiveSheet.QueryTables.Add(Connection:= _
            "TEXT;http://xxx/journal.csv" _
            , Destination:=Range("A1"))
            .Name = "nvaview_1"
            .FieldNames = True
            .RowNumbers = False
            .FillAdjacentFormulas = False
            .PreserveFormatting = True
            .RefreshOnFileOpen = False
            .RefreshStyle = xlInsertDeleteCells
            .SavePassword = False
            .SaveData = True
            .AdjustColumnWidth = True
            .RefreshPeriod = 0
            .TextFilePromptOnRefresh = False
            .TextFilePlatform = 1252
            .TextFileStartRow = 1
            .TextFileParseType = xlDelimited
            .TextFileTextQualifier = xlTextQualifierDoubleQuote
            .TextFileConsecutiveDelimiter = False
            .TextFileTabDelimiter = False
            .TextFileSemicolonDelimiter = True
            .TextFileCommaDelimiter = False
            .TextFileSpaceDelimiter = False
            .TextFileColumnDataTypes = Array(1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1)
            .TextFileTrailingMinusNumbers = True
            .Refresh BackgroundQuery:=False
        End With
    Par contre avec ce code, une boite de dialogue s'ouvre pour me demander le login/mot de passe de mon site alors qu'il n'y en a pas. Comment l'enlever ?

  3. #3
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut

    Bonjour, bonjour !

    P'tit rappel :

    un fichier .csv s'ouvre aussi directement comme un classeur et même via un double clic via l'Explorateur de fichiers !

    Donc une seule ligne de code nécessaire : consulter l'aide VBA intégrée de la méthode Workbooks.Open

    Et ne pas oublier le Générateur de macros, l'ami du débutant !

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    676
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 676
    Par défaut
    Oui mais moi j'ai vraiment besoin de procéder ainsi.
    Sais-tu comment faire pour enlever la demande d'identifiant et mot de passe ?

Discussions similaires

  1. Importer 1 fichier txt dans une feuille de classeur Excel
    Par agtim dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 27/01/2015, 12h34
  2. Réponses: 8
    Dernier message: 11/01/2013, 14h49
  3. [XL-2003] Importer automatiquement un fichier CSV dans une feuille
    Par Mikayel dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 12/06/2009, 10h35
  4. Réponses: 1
    Dernier message: 18/04/2007, 18h13
  5. Réponses: 7
    Dernier message: 23/01/2006, 11h53

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