Commande shell linux
harunabdurrahman
Messages postés
2
Statut
Membre
-
dubcek Messages postés 19021 Statut Contributeur -
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
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:
- Commande shell linux
- Invite de commande - Guide
- Classic shell - Télécharger - Personnalisation
- Commande terminal mac - Guide
- Linux reader - Télécharger - Stockage
- Diskpart commande - Guide
3 réponses
hello
awk ou perl sont probablement plus appropriés que grep, peut-on voir des fichiers d'exemples ?
awk ou perl sont probablement plus appropriés que grep, peut-on voir des fichiers d'exemples ?
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+
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>
$
$
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
les colonnes du fichiers ou du HTML ?
peux-tu montrer le résultat ?
<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 ?