Page 1 sur 1

Comment fusionner plusieurs fichiers Json

Publié : lun. 28/mai/2018 15:29
par Micoute
Bonjour à tous,

pour mon application de dépistage du diabète, on me demande de fusionner toutes les saisies du département, sachant que ces saisies sont dans des fichiers json différents.

Je viens vers vous parce que je tourne en rond sans cesse et surtout sans trouver la solution, en fait quand je clique sur le bouton "Fusionner", il faudrait que ça m'ouvre une procédure capable de lire chaque fichier et me mette les résultats dans une liste.

le problème : comment lister les fichiers et les ouvrir un à un ?


Si vous pouvez m'aider, je vous en remercie par anticipation.

Re: Comment fusionner plusieurs fichiers Json

Publié : lun. 28/mai/2018 15:57
par falsam
Lister les fichier ce n'est pas compliqué : ExamineDirectory()
Ensuite pour chaque fichier json trouvé, extraction dans une liste temporaire.
Et enfin copier la liste temporaire dans le fichier destination avec la commande CopyList()

Code : Tout sélectionner

#JSONFile = 0

Structure NewContact
  departement.i
  nom.s
EndStructure
Global NewList contacts.NewContact()
Global NewList temp.NewContact() 

Procedure ContactAdd(Departement, Nom.s)
  AddElement(contacts())
  contacts()\departement = Departement
  contacts()\nom = Nom
EndProcedure

;Création du fichier JSON du 75
ContactAdd(75, "Marchalombre")
ContactAdd(75, "Balature")
ContactAdd(75, "Zarda")

CreateJSON(#JSONFile)
InsertJSONList(JSONValue(#JSONFile), Contacts())
SaveJSON(#JSONFile, "contacts.75.json")

;Création du fichier JSON du 78
ContactAdd(78, "Dupont")
ContactAdd(78, "Durant")
ContactAdd(78, "Batolou")

CreateJSON(#JSONFile)
InsertJSONList(JSONValue(#JSONFile), Contacts())
SaveJSON(#JSONFile, "contacts.78.json")

;Création du fichier JSON du 92
ContactAdd(92, "Dumartin")
ContactAdd(92, "Alabrioche")
ContactAdd(92, "Babiole")

CreateJSON(#JSONFile)
InsertJSONList(JSONValue(#JSONFile), Contacts())
SaveJSON(#JSONFile, "contacts.92.json")

;Fusion des fichiers
Directory$ = GetCurrentDirectory() ; Tu renseignes le dossier contenant tes JSON
If ExamineDirectory(0, Directory$, "*.json")  
  ClearList(contacts())
  While NextDirectoryEntry(0)    
    Debug "Traitement du fichier " + DirectoryEntryName(0)
    ClearList(temp())
    LoadJSON(#JSONFile, DirectoryEntryName(0), #PB_JSON_NoCase)
    ExtractJSONList(JSONValue(#JSONFile), Temp()) ;Extraction dans une liste temporaire
    CopyList(Temp(), contacts())    
  Wend
  FinishDirectory(0)
  Debug ""
EndIf

;Debug liste fusionnée
ForEach contacts()
Debug "Departement " + contacts()\departement + " Nom " + contacts()\nom  
Next
#PureBasic est formidable ^|^

Re: Comment fusionner plusieurs fichiers Json

Publié : lun. 28/mai/2018 16:35
par Micoute
Un grand merci pour ton aide qui m'est bien salutaire.

Oui, c'est vrai que PureBasic est formidable, dommage que mon cerveau ne sois plus aussi brillant qu'il y a 40 ans.

Par contre j'ai choisi MergeLists() parce que mes fichiers n'ont pas tous le même nombre d'enregistrements.