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

Linux Discussion :

Question sur sed


Sujet :

Linux

  1. #1
    Membre actif
    Avatar de Blo0d4x3
    Inscrit en
    Octobre 2003
    Messages
    584
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 584
    Points : 265
    Points
    265
    Par défaut Question sur sed
    Bonjour,

    Je suis sur un script qui va enregistrer plusieurs variables dans une base de données. Le problème est qu'une de ces variables peut contenir des caractères spéciaux comme la simple quote '. Je voudrais avec sed la backslasher pour qu'elle puisse être enregistrer en base, sinon la requète INSERT plante :-\.

    J'ai essayer plusiseurs façon de subsitutier ce caractère mais sans succès, quelqu'un a une piste?

    Merci

  2. #2
    Invité
    Invité(e)
    Par défaut
    Salut,


    pour faire un insert tu as deux solutions pour le simple quote

    1) tu le backslash (\')
    2) tu le doubles ('')

    La solution deux fonctionne avec le sed.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    wltest1@electre:wltest1$ echo "l'alouette" | sed -e "s/'/''/"
    l''alouette
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    mysql> insert into testtbl (nom) values ('l''alouette');
    Query OK, 1 row affected (0.00 sec)
     
    mysql> select * from testtbl
        -> ;
    +------------+
    | nom        |
    +------------+
    | l'alouette |
    +------------+
    1 row in set (0.00 sec)

  3. #3
    Membre actif
    Avatar de Blo0d4x3
    Inscrit en
    Octobre 2003
    Messages
    584
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 584
    Points : 265
    Points
    265
    Par défaut
    Merci de ta réponse.

    J'a tester ton astuce mais ca donne toujours en erreur.
    J'ai fais comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    VAR_SED=$(echo "$VAR_TMP" | sed -e "s/'/''/")
     
        echo -e "INSERT INTO DataLogs VALUES ('', '$ADDR', '$VAR_NSLOOKUP', '$(date "+%Y/%m/%d %H:%m:%S")', '$VAR_GEOLOOKUP', '', '$VAR_SED', '');" | $MYSQL_PATH -u $SQL_USER --password=$SQL_PASSWORD $DATABASE
    Et l'erreur fatal:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'inetnum:        90.33.20.0 - 90.33.20.255
    netname:        IP2000-ADSL-BAS
    descr:' at line 2

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 731
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 731
    Points : 31 054
    Points
    31 054
    Billets dans le blog
    1
    Par défaut
    C'est pas vraiment une question sur sed mais plutôt une question sur MySQL
    Va voir ici http://dev.mysql.com/doc/refman/5.0/...ng-syntax.html passage "si vous voulez insérer des données binaires dans un champ chaîne (comme un BLOB), les caractères suivants doivent être échappés"

  5. #5
    Membre actif
    Avatar de Blo0d4x3
    Inscrit en
    Octobre 2003
    Messages
    584
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 584
    Points : 265
    Points
    265
    Par défaut
    Oui mais mon problème c'est comment les echappés, il s'agit d'une variable ou je peux avoir des caractères sans que je sache ou qu'elles soient et a par sed je vois pas d'autres solution.

  6. #6
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 731
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 731
    Points : 31 054
    Points
    31 054
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Blo0d4x3 Voir le message
    Oui mais mon problème c'est comment les echappés, il s'agit d'une variable ou je peux avoir des caractères sans que je sache ou qu'elles soient et a par sed je vois pas d'autres solution.
    Non évidemment qu'il faudra utiliser sed pour échapper tes caractères. Mais pour savoir quels caractères il faut échapper, c'est dans la doc MySQL que tu le trouveras...

Discussions similaires

  1. [Shell scripting] Question sur sed et regex
    Par Antheadousa dans le forum Shell et commandes GNU
    Réponses: 3
    Dernier message: 29/05/2014, 10h37
  2. Quelques questions sur le TWebBrowser...
    Par CorO dans le forum Web & réseau
    Réponses: 3
    Dernier message: 17/01/2003, 21h23
  3. Question sur les handles et les couleurs...
    Par MrDuChnok dans le forum C++Builder
    Réponses: 7
    Dernier message: 29/10/2002, 08h45
  4. Réponses: 2
    Dernier message: 11/08/2002, 21h27
  5. question sur les message box !
    Par krown dans le forum Langage
    Réponses: 7
    Dernier message: 02/08/2002, 16h11

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