VBA Excel : Importer XML - xlDialogOpen
Résolu
Eaheru
Messages postés
197
Date d'inscription
Statut
Membre
Dernière intervention
-
HardyPetit -
HardyPetit -
A voir également:
- Excel vba xml
- Liste déroulante excel - Guide
- Xml download - Télécharger - Édition & Programmation
- Word et excel gratuit - Guide
- Déplacer colonne excel - Guide
- Si ou excel - Guide
8 réponses
Bonjour,
et en modifiant le début de la macro comme ceci ? :
NomFichierXML = Application.GetOpenFilename("Fichier XML (*.xml),*.xml", , "Choisir le fichier")
With ActiveSheet.QueryTables.Add(Connection:=NomFichierXML, Destination:=Range("A1"))
...
A+
et en modifiant le début de la macro comme ceci ? :
NomFichierXML = Application.GetOpenFilename("Fichier XML (*.xml),*.xml", , "Choisir le fichier")
With ActiveSheet.QueryTables.Add(Connection:=NomFichierXML, Destination:=Range("A1"))
...
A+
Bonjour,
Peut-être en utilisant cette syntaxe :
NomFichierXML = Application.GetOpenFilename("Fichier XML (*.xml),*.xml", , "Choisir le fichier")
L'utilisateur fait le choix du fichier mais il n'est pas ouvert, c'est le chemin du fichier qui est retourné ici dans la variable NomFichierXML. Retourne FAUX si l'utilisateur ne fait pas de choix.
Il suffit ensuite d'ouvrir le fichier avec la syntaxe :
Workbooks.OpenXML Filename:= NomFichierXML
A tester
A+
Cordialement,
Peut-être en utilisant cette syntaxe :
NomFichierXML = Application.GetOpenFilename("Fichier XML (*.xml),*.xml", , "Choisir le fichier")
L'utilisateur fait le choix du fichier mais il n'est pas ouvert, c'est le chemin du fichier qui est retourné ici dans la variable NomFichierXML. Retourne FAUX si l'utilisateur ne fait pas de choix.
Il suffit ensuite d'ouvrir le fichier avec la syntaxe :
Workbooks.OpenXML Filename:= NomFichierXML
A tester
A+
Cordialement,
Bonjour,
C'est parfait ! :) merci beaucoup pour ce coup de main.
La chose chose a savoir est que la variable NomFichierXML doit etre configurée en "Variant" puisque si l'utilisateur ne choisi pas de fichier il y a un retour booleen (vrai/faux)
Une fois ce détail ajusté, ça marche impeccablement !
Encore Merci
Une question pour terminer complétement ma macro, est il possible d'ouvrir la fenêtre de choix du fichier XML dans un répertoire précis ? Cela faciliterait la vie de mes utilisateurs :)
C'est parfait ! :) merci beaucoup pour ce coup de main.
La chose chose a savoir est que la variable NomFichierXML doit etre configurée en "Variant" puisque si l'utilisateur ne choisi pas de fichier il y a un retour booleen (vrai/faux)
NomFichierXML = Application.GetOpenFilename("Fichier XML (*.xml),*.xml", , "Choisir le fichier") Set wk2 = Workbooks.OpenXML(Filename:=NomFichierXML, LoadOption:=xlXmlLoadImportToList)
Une fois ce détail ajusté, ça marche impeccablement !
Encore Merci
Une question pour terminer complétement ma macro, est il possible d'ouvrir la fenêtre de choix du fichier XML dans un répertoire précis ? Cela faciliterait la vie de mes utilisateurs :)
Bonjour!
je vous présente mon problème:
j'ai un fichier excel contenant certaines données et j'ai besoin d'importer un fichier xml dans CE fichier excel (en créant une nouvelle feuille par exemple).
J'ai réussi à créer une macro réalisant cette tâche (code ci-dessous):
ActiveWorkbook.Worksheets.Add
With ActiveSheet.QueryTables.Add(Connection:="FINDER;E:\Documents and Settings\u0557730\Bureau\PDCA.xml", Destination:=Range("A1"))
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
SAUF QUE la macro va chercher le fichier xml à un emplacement bien défini de l'ordinateur, ce qui n'est pas pratique...
J'ai trouvé sur le forum ce code:
encore:
FichierOk = Application.Dialogs(xlDialogOpen).Show
If Not FichierOk Then
MsgBox " Vous devez choisir un fichier"
GoTo encore
End If
Ce code permet d'ouvrir une fenêtre de recherche pour récupérer le fichier xml à l'endroit de mon choix mais nouveau problème: le fichier xml est importé dans un nouveau fichier excel et non pas dans MON fichier excel!
Je cherche désespéremment depuis une semaine à mixer ces deux programmes afin d'importer par macro ce fichier xml dans mon fichier excel en passant par une fenêtre de recherche...
Quelqu'un pourrait-il m'aider?? J'ai cherché dans tout le forum mais ce problème n'est posé nul part...
je vous présente mon problème:
j'ai un fichier excel contenant certaines données et j'ai besoin d'importer un fichier xml dans CE fichier excel (en créant une nouvelle feuille par exemple).
J'ai réussi à créer une macro réalisant cette tâche (code ci-dessous):
ActiveWorkbook.Worksheets.Add
With ActiveSheet.QueryTables.Add(Connection:="FINDER;E:\Documents and Settings\u0557730\Bureau\PDCA.xml", Destination:=Range("A1"))
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
SAUF QUE la macro va chercher le fichier xml à un emplacement bien défini de l'ordinateur, ce qui n'est pas pratique...
J'ai trouvé sur le forum ce code:
encore:
FichierOk = Application.Dialogs(xlDialogOpen).Show
If Not FichierOk Then
MsgBox " Vous devez choisir un fichier"
GoTo encore
End If
Ce code permet d'ouvrir une fenêtre de recherche pour récupérer le fichier xml à l'endroit de mon choix mais nouveau problème: le fichier xml est importé dans un nouveau fichier excel et non pas dans MON fichier excel!
Je cherche désespéremment depuis une semaine à mixer ces deux programmes afin d'importer par macro ce fichier xml dans mon fichier excel en passant par une fenêtre de recherche...
Quelqu'un pourrait-il m'aider?? J'ai cherché dans tout le forum mais ce problème n'est posé nul part...
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
J'obtiens un message d'erreur:
"Erreur d'execution
Erreur définie par l'application ou par l'objet"
J'ai placé le code comme ceci et l'erreur se situe sur la 4eme ligne:
Range("E31").Select
ActiveWorkbook.Worksheets.Add
PDCA = Application.GetOpenFilename("PDCA (*.xml),*.xml", , "Choisir le fichier")With ActiveSheet.QueryTables.Add(Connection:=PDCA, Destination:=Range("A1"))
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
"Erreur d'execution
Erreur définie par l'application ou par l'objet"
J'ai placé le code comme ceci et l'erreur se situe sur la 4eme ligne:
Range("E31").Select
ActiveWorkbook.Worksheets.Add
PDCA = Application.GetOpenFilename("PDCA (*.xml),*.xml", , "Choisir le fichier")With ActiveSheet.QueryTables.Add(Connection:=PDCA, Destination:=Range("A1"))
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
Oui au temps pour moi j'ai été un peu rapide voila deux corrections :
1/ j'ai ajouté "FINDER"
2/ j'ai traité le cas ou l'utilisateur ne choisit pas de fichier et dans ce cas PDCA prend la valeur False.
Voila le code correct :
A+
1/ j'ai ajouté "FINDER"
2/ j'ai traité le cas ou l'utilisateur ne choisit pas de fichier et dans ce cas PDCA prend la valeur False.
Voila le code correct :
Range("E31").Select ActiveWorkbook.Worksheets.Add PDCA = Application.GetOpenFilename("PDCA (*.xml),*.xml", , "Choisir le fichier") If PDCA <> False Then With ActiveSheet.QueryTables.Add(Connection:="FINDER;" & PDCA, Destination:=Range("A1")) .Name = "PDCA" .FieldNames = True .RowNumbers = False .FillAdjacentFormulas = False .PreserveFormatting = True .RefreshOnFileOpen = False .BackgroundQuery = True .RefreshStyle = xlInsertDeleteCells .SavePassword = False .SaveData = True .AdjustColumnWidth = True .RefreshPeriod = 0 .WebSelectionType = xlAllTables .WebFormatting = xlWebFormattingNone .WebPreFormattedTextToColumns = True .WebConsecutiveDelimitersAsOne = True .WebSingleBlockTextImport = False .WebDisableDateRecognition = False .WebDisableRedirections = False .Refresh BackgroundQuery:=False End With End If
A+
Super methode merci.
j'ai fait quelques arrangements pour corresponde à mon besoin
si cela peut aider quelqu'un.
Dim SheetRenew as String
Dim xmlfilefrom As String
Dim FileFrom as String
Dim SheetName as string
Sub PasteXmlData()
FileFrom = "Fichier.xml"
SheetRenew = "Imported_Data"
For Each ws In Worksheets
SheetName = ws.Name
If SheetName = SheetRenew Then
Sheets(SheetRenew).Visible = True
Sheets(SheetRenew).Select
Application.DisplayAlerts = False
ActiveSheet.Delete
Application.DisplayAlerts = True
End If
Next ws
Sheets.Add.Name = SheetRenew
Sheets(SheetRenew).Select
Range("A1").Select
xmlfilefrom = (ThisWorkbook.Path & "\DataBase\" & FileFrom)
With ActiveSheet.QueryTables.Add(Connection:="FINDER;" & xmlfilefrom, Destination:=ActiveCell)
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
End Sub
j'ai fait quelques arrangements pour corresponde à mon besoin
si cela peut aider quelqu'un.
Dim SheetRenew as String
Dim xmlfilefrom As String
Dim FileFrom as String
Dim SheetName as string
Sub PasteXmlData()
FileFrom = "Fichier.xml"
SheetRenew = "Imported_Data"
For Each ws In Worksheets
SheetName = ws.Name
If SheetName = SheetRenew Then
Sheets(SheetRenew).Visible = True
Sheets(SheetRenew).Select
Application.DisplayAlerts = False
ActiveSheet.Delete
Application.DisplayAlerts = True
End If
Next ws
Sheets.Add.Name = SheetRenew
Sheets(SheetRenew).Select
Range("A1").Select
xmlfilefrom = (ThisWorkbook.Path & "\DataBase\" & FileFrom)
With ActiveSheet.QueryTables.Add(Connection:="FINDER;" & xmlfilefrom, Destination:=ActiveCell)
.Name = "PDCA"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.PreserveFormatting = True
.RefreshOnFileOpen = False
.BackgroundQuery = True
.RefreshStyle = xlInsertDeleteCells
.SavePassword = False
.SaveData = True
.AdjustColumnWidth = True
.RefreshPeriod = 0
.WebSelectionType = xlAllTables
.WebFormatting = xlWebFormattingNone
.WebPreFormattedTextToColumns = True
.WebConsecutiveDelimitersAsOne = True
.WebSingleBlockTextImport = False
.WebDisableDateRecognition = False
.WebDisableRedirections = False
.Refresh BackgroundQuery:=False
End With
End Sub