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

Shell et commandes GNU Discussion :

Transposition de nom de maniere auto : .txt -> .sql


Sujet :

Shell et commandes GNU

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 120
    Points : 63
    Points
    63
    Par défaut Transposition de nom de maniere auto : .txt -> .sql
    Bonjour,

    Je récupère un fichier TOTO.txt que j'analyse et j'en extrait certaines infos puis je les mets dans un fichier .sql pour une insertion dans une base.

    Je voudrai savoir s'il existe un scripte ou une commande qui permet à partir du nom de mon fichier d'origine TOTO.txt de le faire passer en TOTO.sql en sortie de script de maniere automatique car je possede plusieurs fichier mais je ne connais pas forcément leur nom.

    Besoin de plus d'explication dite le moi.

    Merci
    --
    Quand vous marquez "Résolu", pensez aux autres, dites Merci et marquez la solution

  2. #2
    Membre éclairé Avatar de jmelyn
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2007
    Messages
    703
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2007
    Messages : 703
    Points : 823
    Points
    823
    Par défaut
    Ici aussi, il faudrait donner un exemple simple et précis.
    Un problème bien posé est déjà résolu (H. Bergson).

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 120
    Points : 63
    Points
    63
    Par défaut
    j'analyse un fichier TOTO.txt par exemple, le script me créer des fichiers intermédiaires et je voudrai qu'il comporte le nom du fichier principal plus une autre donnée:

    1) TOTO.txt

    2) sed 's/PAPA /("/g' AAA_TOTO.txt > BBB_TOTO.txt

    2)sed 's/PAPA /("/g' BBB_TOTO.txt > AAA_TOTO.txt

    4) cat AAA_TOTO.txt > FINAL_TOTO.sql


    de maniere automatique.

    Avec le dernier fichier, celui en .sql devant comporter obligatoirement le nom principal.
    --
    Quand vous marquez "Résolu", pensez aux autres, dites Merci et marquez la solution

  4. #4
    Rédacteur/Modérateur
    Avatar de Winnt
    Homme Profil pro
    budget et contrôle de gestion
    Inscrit en
    Décembre 2006
    Messages
    1 978
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France

    Informations professionnelles :
    Activité : budget et contrôle de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 978
    Points : 4 130
    Points
    4 130
    Par défaut
    Salut,

    Tu as plus simple comme traitement.
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    mon_fichier="TOTO"
    sed -e 's/PAPA /("/g' -e 's/PAPA /("/g' $(mon_fichier).txt > FINAL_$(mon_fichier).sql
    PS : à vérifier car fait à la va vite au bureau
    Winnt
    Merci de lire les règles du forum LaTeX et Qu'est ce qu'un ECM ?.
    N'hésitez pas à parcourir la FAQ la réponse y est peut-être déjà.
    Pensez au bouton si votre problème est résolu.


    C'est en Linuxant qu'on devient .... geek
    Et c'est en LateXant qu'on devient flemmard
    Mon blog tout neuf.
    Articles : présentation de la distribution Gentoo, Les index sous LaTeX et leur personnalisation.

  5. #5
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Points : 2 505
    Points
    2 505
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ifile=TOTO.txt
    sed 's/PAPA /("/g' $ifile > BBB_$ifile
    sed 's/PAPA /("/g' BBB_$ifile > AAA_$ifile
    cat AAA_$ifile > FINAL_${ifile%.txt}.sql
    Mais tu es sûr que tu as besoin de ces fichiers temporaires ?

  6. #6
    Membre éclairé Avatar de jmelyn
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2007
    Messages
    703
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2007
    Messages : 703
    Points : 823
    Points
    823
    Par défaut
    J'ai réussi à décrypter! Tu sembles vouloir utiliser le nom du fichier d'entrée fichier pour nommer d'autres fichiers au cours du traitement: fichier_tmp1, fichier_tmp2... et fichier_final.

    Si c'est bien cela, il devrait suffir de passer le nom du fichier au script lors de l'appel: monScript fichier. Dans le script, on affecte le nom du fichier à une variable: nomFichier=$1 puis d'utiliser celle-ci pour la création des noms des autres fichiers.
    Un problème bien posé est déjà résolu (H. Bergson).

  7. #7
    Nouveau membre du Club
    Inscrit en
    Octobre 2008
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 30
    Points : 33
    Points
    33
    Par défaut
    Pour faire un traitement sur un ensemble de fichiers, tu vas avoir besoin d'une boucle for.

    Ce qui t'intéresse ici ce n'est pas TOTO.txt, mais «*TOTO*». Donc il faut supprimer cette extension avant de reconcaténer cela avec une nouvelle extension : «*.tmp*» par exemple.

    Si je fais l'hypothèse que les fichiers que tu traites sont les arguments de ta commande, ça donne un truc comme ça*:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for fic in "$@" ; do
       base=`basename "$fic" .txt`
       sed 's/PAPA /("/g' <"$base.1.$$.tmp" >"$base.1.$$.tmp"
       sed 's/PAPA /("/g' <"$base.1.$$.tmp" >"$base.1.$$.tmp"
       mv "$base.1.$$.tmp" "FINAL_$base.sql"
    done
    rm -f *.$$.tmp
    Tu peux remarquer que j'ai modifié d'autres petites choses. Les guillemets sont placés de manière à fonctionner même si ton fichier contient un espace dans son nom. "$$" est une variable spéciale qui est remplacé par le PID de ton script, tu peux donc maintenant exécuter plusieurs fois ce code en même temps (il reste un pb avec le nom du fichier résultat, mais si c'est un paramètre ou bien si tu écris sur la sortie standard, plus de problème. Il faut avoir le réflexe d'utiliser $$ pour les choses temporaires et éviter les conflits de nom).

    J'ai remplacé ton cat par un mv. C'est plus rapide. Mais ce n'est pas pareil pour la gestion des droits, le fichier temporaire devrait avoir des droits très restreint, le fichier "FINAL" peut avoir des droits plus grand.

    Typiquement je résouds ce type de problème écrivant le résultat sur la sortie standard et je laisse l'appelant faire ce qu'il a à faire (redirection ou umask etc.)

Discussions similaires

  1. Récupérer le nom d'un fichier txt
    Par thybe dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 12/03/2009, 17h28
  2. Récupérer le nom d'un fichier Txt
    Par tonton44 dans le forum SQL
    Réponses: 4
    Dernier message: 09/07/2007, 15h35
  3. Ping sur noms machines dans fichiers txt
    Par elbossoso dans le forum Programmation et administration système
    Réponses: 5
    Dernier message: 02/12/2006, 15h42
  4. Nom du champs auto-incrementé
    Par norroy dans le forum Requêtes
    Réponses: 2
    Dernier message: 17/06/2003, 18h30
  5. Nom du champs auto-incrementé
    Par norroy dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 17/06/2003, 18h30

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