Commande shell linux
harunabdurrahman
Messages postés
1
Date d'inscription
Statut
Membre
Dernière intervention
-
dubcek Messages postés 18627 Date d'inscription Statut Contributeur Dernière intervention -
dubcek Messages postés 18627 Date d'inscription Statut Contributeur Dernière intervention -
Bonjour,
j'ai à manipuler des fichiers html contenant des tableaux avec le shell de linux, le but etant de creer un script faisant une table de hachage entre deux colonnes dudit tableau puis parcourir le second tableau pour remplacer les donnees d'une colonne par une autre, [ar exemple faire un hachage entre username et ID, et apres parcourir le second tableau et remplacer id par username,
avez vous une idee? je suis bloqué avec la commande grep!
merci beaucoup de votre aide,
bonne journée
j'ai à manipuler des fichiers html contenant des tableaux avec le shell de linux, le but etant de creer un script faisant une table de hachage entre deux colonnes dudit tableau puis parcourir le second tableau pour remplacer les donnees d'une colonne par une autre, [ar exemple faire un hachage entre username et ID, et apres parcourir le second tableau et remplacer id par username,
avez vous une idee? je suis bloqué avec la commande grep!
merci beaucoup de votre aide,
bonne journée
3 réponses
-
hello
awk ou perl sont probablement plus appropriés que grep, peut-on voir des fichiers d'exemples ?-
Salut Dubcek,
merci pour ta réponse,
voici un extrait:
le premier tableau contient des lignes comme suit:
<tr>
<td><ft55545b/>fwcstest124<ft55545e/></td>
<td><ft55545b/>9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684<ft55545e/></td>
<td><ft55545b/>1259831827224<ft55545e/></td>
</tr>
la première colonne contient le username, et la troisième líd,
le second tableau contient des lignes comme suit:
<tr>
<td><ft22849b/>1229294916287<ft22849e/></td>
<td><ft22849b/>userid=1259067363464,ou=People<ft22849e/></td>
<td><ft22849b/>ContentApprover<ft22849e/></td>
<td><ft22849b/>1229294722517<ft22849e/></td>
</tr>
le but est de remplacer le userid dans la seconde colonne par le username correspondant à cet id qui figure dans le premier tableau,.
Merci -
-
-
le premier tableau contient des lignes comme suit:
<tr>
<td><ft55545b/>fwcstest124<ft55545e/></td>
<td><ft55545b/>9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684<ft55545e/></td>
<td><ft55545b/>1259831827224<ft55545e/></td>
</tr>
la première colonne contient le username, et la troisième líd,
quel est le username , quel est l'id ? -
Salut,
jp@MDK:~/tmpfs ssh$ cat tableau <tr> <td><ft55545b/>fwcstest124<ft55545e/></td> <td><ft55545b/>9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684<ft55545e/></td> <td><ft55545b/>1259831827224<ft55545e/></td> </tr> <br> la première colonne contient le username, et la troisième líd, <br> le second tableau contient des lignes comme suit: <br> <tr> <td><ft22849b/>1229294916287<ft22849e/></td> <td><ft22849b/>userid=1259067363464,ou=People<ft22849e/></td> <td><ft22849b/>ContentApprover<ft22849e/></td> <td><ft22849b/>1229294722517<ft22849e/></td> </tr> <br> jp@MDK:~/tmpfs ssh$ w3m -dump -T text/html tableau fwcstest124 9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684 1259831827224 la première colonne contient le username, et la troisième líd, le second tableau contient des lignes comme suit: 1229294916287 userid=1259067363464,ou=People ContentApprover 1229294722517 jp@MDK:~/tmpfs ssh$
-
-
A coups de awk grep et sed, ça doit pouvoir le faire, perl, shell, php, idem.
Si tes balises sont toujours les mêmes, il te "suffit" de remplacer CECI par CELA
userid=[CECI],
<tr><td><ft55545b/>[CELA]</td>
en gras, les balises que entourent tes variables.
A+ -
il faudrait plus de données pour tester
$ cat a1 <tr> <td><ft55545b/>fwcstest124<ft55545e/></td> <td><ft55545b/>9d4e1e23bd5b727046a9e3b4b7db57bd8d6ee684<ft55545e/></td> <td><ft55545b/>1259831827224<ft55545e/></td> </tr> $ cat a2 <tr> <td><ft22849b/>1229294916287<ft22849e/></td> <td><ft22849b/>userid=1259831827224,ou=People<ft22849e/></td> <td><ft22849b/>ContentApprover<ft22849e/></td> <td><ft22849b/>1229294722517<ft22849e/></td> </tr> $ $ awk -F"[<>]" 'NF < 4 {i=0} ; NR==FNR && NF > 4 {x[i++]=$5 ; if (i==3)y[$5]=x[i-3]; next} ;/userid/{split($5, a, "[=,]"); sub("=[0-9][0-9]*,","=" y[a[2]] ",",$0)}; NR!=FNR{print $0}' a1 a2 <tr> <td><ft22849b/>1229294916287<ft22849e/></td> <td><ft22849b/>userid=fwcstest124,ou=People<ft22849e/></td> <td><ft22849b/>ContentApprover<ft22849e/></td> <td><ft22849b/>1229294722517<ft22849e/></td> </tr> $ $