Résultats commande AWK
Résolu/Fermépcsystemd Messages postés 689 Date d'inscription dimanche 27 novembre 2005 Statut Membre Dernière intervention 16 octobre 2023 - 4 oct. 2022 à 16:23
- Samia, kevin et jason ont gardé la trace de leurs ventes quotidiennes du mois de juillet 2016. dans la feuille bilan, il manque les résultats de jason. insérez une colonne entre samia et kevin et reportez-y les résultats de jason. quel mot secret apparait en f2 ?
- Piratage facebook changer mot de passe - Guide
- Mot de passe administrateur freebox ✓ - Forum Freebox
- Site de vente entre particulier - Guide
- Dans le texte, un seul mot a réellement été écrit en lettres capitales (majuscules). quel est ce mot ? - Forum Word
- Les sites web peuvent garder la trace de votre navigation en déposant des - Forum Logiciels
7 réponses
Modifié le 26 sept. 2022 à 17:45
Bonjour,
Je n'ai pas le ; a la fin de chaque ligne d'INSERT
Eh bien ajoute un ; devant ton \n :-)
"INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s);\n"
J'ai des espaces en trop après la première côte simple dans le dernier champ. Exemple ( ' TERE D'ENL')
Il faudrait voir le contenu des variables. Sans exemple de file.sql dur à dire. Mais voici un exemple qui illustre une concaténation.
echo "" | awk '{a="A"; b="B"; print a b a}' # Affiche ABA
Pour toutes les chaines avec une simple côte comme par exemple ' TERE D'ENL' il faudrait que j'ai comme sortie via AWK : E'TERE D\'ENL
Si j'ai bien compris, tu veux remplacer chaque ' par \' ? Si c'est bien ça, tu peux t'inspirer de cette astuce :
echo "aujourd'hui" | awk '{s=$0; gsub("\x27", "\\\x27", s); print s}' # Affiche aujourd\'hui
Bonne chance
27 sept. 2022 à 16:51
hello
pour supprimer les espaces au début ou à la fin d'un champ, mettre comme séparateur -F " *[|] *"
$ echo "A | B | C" |awk -F "|" '{print $1 $2 $3}' A B C $ echo "A | B | C" |awk -F " *[|] *" '{print $1 $2 $3}' ABC
Modifié le 3 oct. 2022 à 09:00
Bonjour,
Merci à vous deux cela fonctionne sauf concernant le point 3 càd
- Pour toutes les chaines avec une simple côte comme par exemple ' TERE D'ENL' il faudrait que j'ai comme sortie via AWK : E'TERE D\'ENL
Ce que je souhaite c'est de remplacer toutes les chaines de caractères ayant dans leurs noms une simple côte.
Exemple :
' TERE D'ENL' par E'TERE D\'ENL' :
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (8369, 21853 , 2365994980 , E'TERE D\'ENL')
'9 COSA D'ESE' par E'9 COSA D\'ESE'
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (8369, 21853 , 2365994980 , E'9 COSA D\'ESE')
etc..
3 oct. 2022 à 14:29
Bonjour
Est-ce que ceci répond à ton problème ?
echo "TERE D'ENL" | awk '{s=$0; gsub("\x27", "\\\x27", s); print "E\x27" s "\x27"}'
Résultat :
E'TERE D\'ENL'
Bonne chance
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre questionModifié le 4 oct. 2022 à 12:38
Merci.
J'ai fais des tests mais non concluants car je n'arrive pas à intégrer la solution :
{s=$0; gsub("\x27", "\\\x27", s); print "E\x27" s "\x27"}
... dans ma commande AWK ci-dessous :
awk -F \| -v Q=\' '{ prov=($1~/^ *$/)?"":uid;printf ("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, Q $4 Q) }' file.sql
Une idée ?
Modifié le 4 oct. 2022 à 14:15
Bonjour,
Avoir un exemple minimal de file.sql serait idéal, mais si j'ai bien compris ton code, ce que j'ai appelé s et qui était initialisé à $0 correspond dans ton cas $4. Je n'ai pas trop compris à quoi servait la variable prov dans ton script awk (à mon avis elle ne sert à rien) donc du coup je l'ai supprimée dans ce qui suit.
awk -F \| '{s=$4; gsub("\x27", "\\\x27", s); printf("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, "E\x27" s "\x27")}' file.sql
file.sql
Voici ce que j'ai cru deviner de la structure d'une ligne type de ton fichier .sql :
UID | CO | REF_G | TERE D'ENL
Résultat de la commande proposée
awk -F \| '{s=$4; gsub("\x27", "\\\x27", s); printf ("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, "E\x27" s "\x27")}' file.sql
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (0, CO , REF_G , E' TERE D\'ENL')
Remarque
- Indépendamment des histoires de awk, je te suspecte d'avoir un dump dans lequel les colonnes sont séparées par des | et que tu veux recharger dans postgresql sauf qu'à cause des séparateurs, tu dois retraiter le fichier pour pouvoir le charger en base.
- Or normalement si ton dump a été bien construit, tu as directement des directives SQL dedans (c'est ce que ferait mysqldump et j'imagine pg_dump). Et du coup tu n'aurais pas à faire toutes ces bidouilles avec awk.
- As-tu regardé ?
Bonne chance
Modifié le 4 oct. 2022 à 14:43
Merci je viens de tester.
Cela ajoute bien le E mais a tous les champs 'nal' alors qu'il faut ajouter ce E que pour els champ contenant une simple côte dans le nom et n'ajoute pas le \
Voici le contenu du fichier a traiter :
id_ace | ce | real | nal
------------+-------+------------+--------------------
172729759 | 3405 | 12 | 9 COSA D'ESE
14981206 | 3316 | 23654980 | TERE D'ENL
33157859 | 3654 | 5 | D LEVT
1892720 | 2303 | 27 | L CONANT
15432905 | 3335 | 2 | D'EMDE
2425365 | 2836 | 7 | HP'LAUT !
26330353 | 3612 | 1 | PAIS
2425349 | 2832 | 28272083 | DE L'ARE
Voici le résultat lorsque l'on joue la commande
awk -F " *[|] *" -v Q=\' '{s=$4; prov=($1~/^ *$/)?"":uid;printf ("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, "E\x27" s "\x27")}' file.txt
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (172729759, 3405, 12, E'9 COSA D'ESE')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (14981206, 3316, 23654980, E'TERE D'ENL')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (33157859, 3654, 5, E'D LEVT')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (1892720, 2303, 27, E'L CONANT')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (15432905, 3335, 2, E'D'EMDE')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (2425365, 2836, 7, E'HP'LAUT !')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (26330353, 3612, 1, E'PAIS')
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (2425349, 2832, 28272083, E'DE L'ARE')
Concernant mon fichier traité non il n'est pas séparé par des | et il s'intègre correctement dans ma BDD postgresql.
4 oct. 2022 à 14:41
Nos réponses se sont croisées, j'ai oublié dans la première version l'instruction avec gsub que j'ai rajoutée ensuite. Donc, reprends mon message.#6 :
awk -F \| '{s=$4; gsub("\x27", "\\\x27", s); printf ("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, "E\x27" s "\x27")}' file.sql
Ceci dit, maintenant que je vois ton fichier sql, j'ignorerais les 2 premières lignes à l'aide de tail et donc la commande devient :
tail -n +3 file.sql | awk -F \| '{s=$4; gsub("\x27", "\\\x27", s); printf ("INSERT INTO table (uid, co, ref_g, no_gl) VALUES (%d, %s, %s, %s)\n", $1, $2, $3, "E\x27" s "\x27")}'
Résultat :
INSERT INTO table (uid, co, ref_g, no_gl) VALUES (172729759, 3405 , 12 , E' 9 COSA D\'ESE') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (14981206, 3316 , 23654980 , E' TERE D\'ENL') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (33157859, 3654 , 5 , E' D LEVT') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (1892720, 2303 , 27 , E' L CONANT') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (15432905, 3335 , 2 , E' D\'EMDE') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (2425365, 2836 , 7 , E' HP\'LAUT !') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (26330353, 3612 , 1 , E' PAIS') INSERT INTO table (uid, co, ref_g, no_gl) VALUES (2425349, 2832 , 28272083 , E' DE L\'ARE')
Ceci étant dit, reste toujours cette histoire de pg_dump en suspens...
Bonne chance
4 oct. 2022 à 16:23
Merci.