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 :

Modification d'un URL via excel (inputbox par ex) [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Homme Profil pro
    GDP
    Inscrit en
    Avril 2012
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : GDP
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2012
    Messages : 5
    Par défaut Modification d'un URL via excel (inputbox par ex)
    Bonjour,

    J'aimerai importer des données via un URL sur excel, ce qui fonctionne très bien avec le code suivant mais j'aimerai que l'utilisateur puisse sous excel modifier cet URL pour pouvoir accéder à des données différentes (la date fin par exemple définie dans l'URL par f=2012)

    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
    With ActiveSheet.QueryTables.Add(Connection:= _
            "URL;http://ichart.finance.yahoo.com/table.csv?s=%5EGSPC&a=00&b=1&c=2002&d=03&e=27&f=2012&g=m&ignore=.csv" _
            , Destination:=Range("$A$1"))
            .Name = "hp?s=%5EGSPC&b=1&a=00&c=2002&e=27&d=03&f=2012&g=m"
            .FieldNames = True
            .RowNumbers = False
            .FillAdjacentFormulas = False
            .PreserveFormatting = True
            .RefreshOnFileOpen = False
            .BackgroundQuery = True
            .RefreshStyle = xlInsertDeleteCells
            .SavePassword = False
            .SaveData = True
            .AdjustColumnWidth = True
            .RefreshPeriod = 0
            .WebSelectionType = xlSpecifiedTables
            .WebFormatting = xlWebFormattingNone
            .WebTables = "15"
            .WebPreFormattedTextToColumns = True
            .WebConsecutiveDelimitersAsOne = True
            .WebSingleBlockTextImport = False
            .WebDisableDateRecognition = False
            .WebDisableRedirections = False
            .Refresh BackgroundQuery:=False
        End With
    J'ai essayé avec une inputbox comme suit:

    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
     
    Dim anneefin as integer
    anneefin = inputbox("saisir année de fin")
    With ActiveSheet.QueryTables.Add(Connection:= _
            "URL;http://ichart.finance.yahoo.com/table.csv?s=%5EGSPC&a=00&b=1&c=2002&d=03&e=27&f=2012&g=m&ignore=.csv" _
            , Destination:=Range("$A$1"))
            .Name = "hp?s=%5EGSPC&b=1&a=00&c=2002&e=27&d=03&f=anneefin&g=m"
            .FieldNames = True
            .RowNumbers = False
            .FillAdjacentFormulas = False
            .PreserveFormatting = True
            .RefreshOnFileOpen = False
            .BackgroundQuery = True
            .RefreshStyle = xlInsertDeleteCells
            .SavePassword = False
            .SaveData = True
            .AdjustColumnWidth = True
            .RefreshPeriod = 0
            .WebSelectionType = xlSpecifiedTables
            .WebFormatting = xlWebFormattingNone
            .WebTables = "15"
            .WebPreFormattedTextToColumns = True
            .WebConsecutiveDelimitersAsOne = True
            .WebSingleBlockTextImport = False
            .WebDisableDateRecognition = False
            .WebDisableRedirections = False
            .Refresh BackgroundQuery:=False
        End With
    Mais en vain cela ne fonctionne pas !
    Merci d'avance !

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonjour,

    En intégrant ta variable dans la chaine mais afin d'éviter les erreurs, il te faudrais contrôler la saisie :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ActiveSheet.QueryTables.Add(Connection:="URL;http://ichart.finance.yahoo.com/table.csv?s=%5EGSPC&a=00&b=1&c=2002&d=03&e=27&f=" & anneefin & "&g=m&ignore=.csv", Destination:=Range("$A$1"))
    Hervé.

  3. #3
    Membre du Club
    Homme Profil pro
    GDP
    Inscrit en
    Avril 2012
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : GDP
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2012
    Messages : 5
    Par défaut
    Merci Hervé ! j'avais essayé de cette façon mais j'ai mal placé mes espaces avec les & et ".

    Encore merci

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

Discussions similaires

  1. modification de l'url envoyer par une servlet
    Par stevelaclasse dans le forum Servlets/JSP
    Réponses: 0
    Dernier message: 30/06/2013, 18h54
  2. [XL-2000] Modification d'un fichier word via excel
    Par zeralium dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 13/11/2009, 16h04
  3. Limites Création table tempo Access par ADOX via Excel VBA.
    Par botakelymg dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 16/11/2007, 09h45
  4. Connexion base SQL via Excel
    Par dp_favresa dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/01/2005, 14h32
  5. [FireBird] Accéder à une vue via Excel
    Par Vonotar dans le forum Débuter
    Réponses: 1
    Dernier message: 07/12/2004, 09h31

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