Précédent   Forum des professionnels en informatique > Systèmes > Linux > Applications > Shell
Shell Vos questions sur l'utilisation des commandes shell
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
Vieux 15/03/2010, 14h26   #1
Membre du Club
 
Inscription : mai 2008
Messages : 217
Détails du profil
Informations personnelles :
Localisation : France, Somme (Picardie)

Informations forums :
Inscription : mai 2008
Messages : 217
Points : 40
Points : 40
Envoyer un message via MSN à miketidy
Par défaut Commande awk pour comparer deux fichiers

Bonjour,

Voilà j'ai deux fichiers qui ont un format quelque peu différent :

Fichier 1 :
Citation:
POSTPO16FGRCQC POST 00000007513085566440005001S020SEDIACHAT 20090825200908242009082420090824
POSTPO16FGRCSK POST 000003N2000050022220005001S020RACHVENTE 20090825200908242009082420090824
Bon entre le premier groupe et le deuxième, il y a beaucoup plus d'espace. en gros ce que je veux récupérer, c'est la chaine de la position 75 qui fait 19 caractères et je veux la comparer au fichier ci-dessous :
Citation:
000003N200005001111
000003N200005002222
000003N200005003333
Si la chaine récupérée du premier fichier correspond à l'une des chaines du 2ème fichier => recopier la ligne entière du premier fichier dans un troisième fichier en sortie.

Ma question est : est-il possible de faire çà avec awk et comment faire (cela fait longtemp que je n'ai pas touché à awk...)?

Merci d'avance,
miketidy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/03/2010, 15h40   #2
Membre du Club
 
Inscription : mai 2008
Messages : 217
Détails du profil
Informations personnelles :
Localisation : France, Somme (Picardie)

Informations forums :
Inscription : mai 2008
Messages : 217
Points : 40
Points : 40
Envoyer un message via MSN à miketidy
Bon finalement, je crois que j'ai trouvé mais bon je ne sais pas si syntaxiquement c'est bon :
Citation:
awk 'NR==FNR{a[$1]=substr($0,75,19);next}{if(substr($0,75,19)in a) printf $0"\n"}' file b file a
miketidy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/03/2010, 19h45   #3
Membre chevronné
 
Inscription : septembre 2007
Messages : 685
Détails du profil
Informations personnelles :
Âge : 48
Localisation : Suisse

Informations forums :
Inscription : septembre 2007
Messages : 685
Points : 723
Points : 723
Bonsoir,

Vu le code awk que tu mets là, ça doit faire effectivement un certain temps que tu n'as pas touché à du code. Il ne peut pas marcher et de très loin. Voici un code qui devrait fonctionner. Je ne l'ai pas testé parce que ce que tu donnes en exemple n'est pas utilisable.
Code :
awk '{key=substr($0, 75, 19); if (system("grep -q ^" key "$ fichier_b") == "0") print}' fichier_a > fichier_c
Si jamais tu ne comprenais pas une partie du code, dis-le et je te l'expliquerai.
__________________
Un problème bien posé est déjà résolu (H. Bergson).
jmelyn est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +1. Il est actuellement 20h13.


 
 
 
 
Partenaires

Hébergement Web