Ce programme permet d'exporter la liste des publications disponibles dans le catalogue Cafeyn/Bouygues dans un fichier XML.
Ce programme a été développé en réponse à une demande d'assistance postée sur le groupe Facebook "Entraide Excel Et VBA"
Pouvoir disposer de la liste des publications disponibles dans le Catalogue Cafey pour Bouygues dans un fichier Excel.
NOK : Toutes les publications sont dans la même cellule.
En analysant le code HTML de la page, nous pouvons constater que les publications sont représentées par des balises <a>
, il ne s'agit pas d'un "vrai" tableau HTML mais d'une mise en forme. Excel n'est donc pas capable d'identifier les cellules du tableau lors du copier/coller.
NOK : Lors de l'utilisation comme source de données, aucune donnée récupérée.
Après analyse du code HTML de la page et des échanges réseaux, nous pouvons constater qu'il s'agit d'appels asynchrones et que le contenu est chargé dynamiquement par le navigateur. Par conséquent, Excel n'étant pas capable de prendre en charge ce type d'interaction, il n'est pas possible de se servir de l'URL comme source de données.
Après analyse des appels effectués à l'API, il paraît tout à fait envisageable de développer un programme capable de :
- interroger l'API utilisée par le navigateur pour récupérer la liste des publications au format JSON
- transformer ces données pour les mettre au format XML qu'Excel saura interpréter sans difficultés.
Le fichier XML représente un tableau de PublicationDataRow
.
Cette structure contient les propriétés suivantes :
Propriétés | Correspondance avec réponse API |
---|---|
StoreId | result.stores[i].storeId |
StoreName | result.stores[i].name |
CategoryId | result.stores[i].categories[j].id |
CategoryName | result.stores[i].categories[j].name |
PublicationId | result.stores[i].categories[j].items[k].publicationId |
PublicationName | result.stores[i].categories[j].items[k].title |
Visual Studio 2019
Amael BERTEAU
This project is licensed under the MIT License - see the LICENSE file for details