Commande shell linux

harunabdurrahman Messages postés 2 Statut Membre -  
dubcek Messages postés 19021 Statut Contributeur -
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





A voir également:

3 réponses

dubcek Messages postés 19021 Statut Contributeur 5 637
 
hello
awk ou perl sont probablement plus appropriés que grep, peut-on voir des fichiers d'exemples ?
0
harunabdurrahman Messages postés 2 Statut Membre
 
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
0
dubcek Messages postés 19021 Statut Contributeur 5 637
 
la première colonne contient le username, et la troisième líd,
les colonnes du fichiers ou du HTML ?
peux-tu montrer le résultat ?
0
foobar47 Messages postés 13654 Statut Contributeur 533
 
Il va travailler sur le fichier sans doute et non sur le rendu... non ?
0
dubcek Messages postés 19021 Statut Contributeur 5 637
 
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 ?
0
jipicy Messages postés 41342 Statut Modérateur
 
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$
0
foobar47 Messages postés 13654 Statut Contributeur 533
 
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+
0
dubcek Messages postés 19021 Statut Contributeur 5 637
 
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>
$ 
$ 
0