Forum |  HardWare.fr | News | Articles | PC | S'identifier | S'inscrire | Shop Recherche
1561 connectés 

  FORUM HardWare.fr
  Programmation
  Shell/Batch

  Traitement de fichier automatisé

 



 Mot :   Pseudo :  
 
Bas de page
Auteur Sujet :

Traitement de fichier automatisé

n°2047236
bobl'epong​e
Posté le 07-01-2011 à 14:05:39  profilanswer
 

Bonjour a tous  :hello:  
 
Bon voila mon problème  :D  
 
Je reçois régulièrement un fichier XML qui contient certaines informations qu'ils faut mettre dans une base de données Mysql, je recherche un moyen qui me permettrai de nettoyer ce fichier afin qu'il ne reste que les informations qui m'intéresse et puis les insérer dans la BDD.
 
Travaillant sur une debian lenny j'ai recherché un outil qui m'aiderai pour cette automatisation, je suis tombé sur AWK mais après avoir lu la doc j'ai pas l'impression qu'il me soit d'une grande aide  :sweat:  
http://nyal.developpez.com/tutoriel/gawk/gawk.pdf
 
Connaissez vous un moyen qui me permettrai de faire cela ?
 
Merci  :jap:


Message édité par bobl'eponge le 18-01-2011 à 15:09:09
mood
Publicité
Posté le 07-01-2011 à 14:05:39  profilanswer
 

n°2047250
mr simon
Posté le 07-01-2011 à 14:19:05  profilanswer
 

Je dirais que ca depends de la complexite de ton fichier xml, et du traitement que tu as besoin de faire.
 
Si c'est plus complique que filtrer certains lignes / champs (tu devrais t'en sortir avec sed et/ou awk - poste ce que tu n'arrives pas a faire), je me dirigerais vers un langage type python ou perl qui possede des modules pour faciliter le traitement des fichiers XML (tu pourras egalement faire l'insert en base de donnees directement depuis ce script)

n°2047277
bobl'epong​e
Posté le 07-01-2011 à 14:40:53  profilanswer
 

Merci de ta réponse a premier vu Sed va pas mal m'aider.
 
En ce qui concerne la complexité du fichier j'ai pas l'impression qu'elle soit trop élever (mais bon je peux me tromper je suis loin d'etre un expert  :whistle: ) puisque les données qui m'intéresse sont a des lignes précise et toujours entouré de la même façon.
 
Encore merci  :jap:

n°2047462
gilou
Modérateur
Modzilla
Posté le 07-01-2011 à 19:33:19  profilanswer
 

Un coup de XSLT pour ne garder que ce qui t'intéresse en sortie?
A+,


---------------
There's more than what can be linked! --    Iyashikei Anime Forever!    --  AngularJS c'est un framework d'engulé!  --
n°2049506
bobl'epong​e
Posté le 16-01-2011 à 19:50:46  profilanswer
 

Bon j'ai pas mal avancé !  :pt1cable:  
 
 
A partir du xml j'ai généré 2 fichiers qui continent mes données
 
le premier est nickel filtré grâce a grep et sed
 
Mais je suis bloqué sur le second  
 
Chaque ligne du second fichier est constitué ainsi  

Code :
  1. Chaine de caractère a longueur variable début de la partie qui m'intéresse chaine a longueur variable qui m'intéresse fin de la partie qui m'intéresse chaine de caractère a longueur variable


Les partie verte sont toujours les même
 
Je voudrai supprimer les partie rouge mais vu qu'elle ne sont jamais les même je sais pas quoi faire  
 
Si vous avez une idée n'hésite pas
 
 
Merci  :jap:


Message édité par bobl'eponge le 16-01-2011 à 19:53:51
n°2049893
bobl'epong​e
Posté le 18-01-2011 à 15:09:14  profilanswer
 

up

n°2049956
Nukolau
Posté le 18-01-2011 à 17:46:00  profilanswer
 

Salut

 
Code :
  1. sed 's/^.*debut_chaine\(.*\)fin_chaine.*$/\1/' ton_fichier
 

devrait répondre a ton besoin je pense.
bien sur debut_chaine et fin_chaine correspondent à tes parties vertes

 

EDIT : attention ca supprime aussi les parties vertes ;) mais vu que tu les connais tu peux les ajouter avant et apres le \1 ou alors protéger ton debut_chaine et fin_chaine avec des \( \) et mettre dans la 2eme partie du sed des \1\2\3


Message édité par Nukolau le 18-01-2011 à 17:48:29
n°2049997
bobl'epong​e
Posté le 18-01-2011 à 20:10:51  profilanswer
 

Mille milliard de Merci  [:cacatomique:2]  
 
et le lien qui va avec  
http://www.koreus.com/animation/million-thanks.html


Aller à :
Ajouter une réponse
  FORUM HardWare.fr
  Programmation
  Shell/Batch

  Traitement de fichier automatisé

 

Sujets relatifs
[VBA - Excel] Vlookup vers un autre fichierDésinstaller un fichier .bin
XML XSL propriété text indent sur plusieurs lignes...Impossible de déployer un fichier WAR sur Jonas 5.1.5
lier un fichierOuvrir un fichier sur un share
Controle nom fichier VBSlire seconde ligne d'un fichier avec fgets en c
Upload fichier et notification par mail !ouverture fichier texte
Plus de sujets relatifs à : Traitement de fichier automatisé


Copyright © 1997-2022 Hardware.fr SARL (Signaler un contenu illicite / Données personnelles) / Groupe LDLC / Shop HFR