Mise en forme de données récupérées

Résolu/Fermé
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014 - 24 juin 2014 à 11:08
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014 - 7 juil. 2014 à 14:03
Bonjour à tous,

Voici mon problème :

Des mails sont envoyés à une adresse qui les convertit en fichiers .txt
Sur ces fichiers .txt, je dois récupérer l'expéditeur du mail (le From), le destinataire (le To) et la date d'envoi.

La conversion des mails en fichiers .txt donne cela :

From: "DUPONT Pierre [CERA]" <dupont.pierre@gmail.fr>
To: =?iso-8859-1?Q?MARTIN_Julien_=5BCERA=5D?=
<julien.martin@gmail.fr>
Subject: SAV AGENCE
Thread-Topic: SAV AGENCE
Thread-Index: Ac+JYBcZ/f1fG23NS82TEygEo3u5mw==
Date: Mon, 16 Jun 2014 14:45:08 +0200


Pour l'instant mon code est le suivant :

Code
#echo "Recuperation de l'expediteur"
#EXPEDITEUR=$(awk 'BEGIN {FS = ":";} $1 == "From" {print $0;}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)
#
#echo "Recuperation de la date"
#DATE_ENVOI=$(awk 'BEGIN {FS = ":";} $1 == "Date" {print $0;}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)

RES=$(awk 'BEGIN {FS = ":"; varFrom = ""; varTo = ""; varDate = ""; flag = 0;}
$1 == "Subject" {flag=0;}
flag == 1 {varTo = varTo $0;}
$1 == "From" {varFrom = $0;}
$1 == "To" {varTo = $0; flag=1;}
$1 == "Date" {varDate = $0;}
END {print varFrom "µ"; print varTo "µ"; print varDate;}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)

echo ${RES} | IFS="µ" read EXPEDITEUR DESTINATAIRE DATE_ENVOI

$EXPEDITEUR =

echo "EXPEDITEUR=${EXPEDITEUR}"
echo "DESTINATAIRE=${DESTINATAIRE}"
echo "DATE_ENVOI=${DATE_ENVOI}"




Et me permet de récupérer les données sous cette forme :


EXPEDITEUR=From: "DUPONT Pierre" <pierre.dupont@gmail.fr>
DESTINATAIRE= To: =?iso-8859-1?Q?MARTIN_Julien_=5BCERA=5D?=
<julien.martin@gmail.fr>
DATE_ENVOI= Date: Mon, 16 Jun 2014 14:45:08 +0200




Mon problème concerne en fait la mise en forme de ces données récupérées :
- J'aimerais récupérer seulement l'adresse mail qui est entre <> pour l'expéditeur
- Idem pour le destinataire (à noter que pour l'instant je récupère le destinataire sur deux lignes et c'est seulement la 2ème qui m'intéresse)
- Pour la date, j'aimerai la convertir en JJ/MM/AAAA


Merci d'avance pour votre aide !


5 réponses

zipe31 Messages postés 36402 Date d'inscription dimanche 7 novembre 2010 Statut Contributeur Dernière intervention 27 janvier 2021 6 407
24 juin 2014 à 12:11
Salut,

Pour les trois lignes à récupérer :

$ cat plop 
From: "DUPONT Pierre [CERA]" <dupont.pierre@gmail.fr>
To: =?iso-8859-1?Q?MARTIN_Julien_=5BCERA=5D?=
<julien.martin@gmail.fr>
Subject: SAV AGENCE
Thread-Topic: SAV AGENCE
Thread-Index: Ac+JYBcZ/f1fG23NS82TEygEo3u5mw==
Date: Mon, 16 Jun 2014 14:45:08 +0200

$ grep -Po '(<|Date: )\K[^>]*' plop
dupont.pierre@gmail.fr
julien.martin@gmail.fr
Mon, 16 Jun 2014 14:45:08 +0200

Et pour la date (à partir de la dernière ligne récupérée) :

$ date -d 'Mon, 16 Jun 2014 14:45:08 +0200' '+%d/%m/%Y'
16/06/2014

1
dubcek Messages postés 18718 Date d'inscription lundi 15 janvier 2007 Statut Contributeur Dernière intervention 22 mars 2024 5 615
24 juin 2014 à 12:26
hello
en supposant que le destinataire est toujours à la ligne suivant le To:
essayer
$ read EXP DEST DATE <<<$(awk -F "[<> ]" '/^From:/ {print $(NF-1)} /^To:/ {getline; print $(NF-1)} /^Date:/ {$1=""; print}' fichier)
$ DATE=$(date -d "$DATE" "+%d/%m/%Y")
$ printf "%s\n" $EXP $DEST $DATE
dupont.pierre@gmail.fr
julien.martin@gmail.fr
16/06/2014
1
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014
24 juin 2014 à 14:58
Merci à vous deux pour vos réponses !

Etant débutant dans ce langage de programmation, je n'ai pas trop compris l'explication de zipe31.. notamment le $ cat plop . Il permet de récupérer les données telles que je les ai déjà actuellement ?

dubcek voici l'état de mon code actuellement :

# == Suivi - Debut des traitements
${SUIVI_DEBUT} ${ID_TRT} SHELL $0


RES=$(awk 'BEGIN {FS = ":"; varFrom = ""; varTo = ""; varDate = ""; flag = 0;}
$1 == "Subject" {flag=0;}
flag == 1 {varTo = varTo $0;}
$1 == "From" {varFrom = $0;}
$1 == "To" {varTo = $0; flag=1;}
$1 == "Date" {varDate = $0;}
END {print varFrom "µ"; print varTo "µ"; print varDate;}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)


echo ${RES} | IFS="µ" read EXPEDITEUR DESTINATAIRE DATE_ENVOI <<<$(awk -F "[<> ]" '/^From:/ {print $(NF-1)} /^To:/ {getline; print $(NF-1)} /^Date:/ {$1=""; print}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)
$ DATE_ENVOI=$(date -d "$DATE_ENVOI" "+%d/%m/%Y")

echo "EXPEDITEUR=${EXPEDITEUR}"
echo "DESTINATAIRE=${DESTINATAIRE}"
echo "DATE_ENVOI=${DATE_ENVOI}"


Ca fonctionne bien pour l'expéditeur, je ne récupère rien pour le destinataire, et pour la date ça ne fonctionne pas non plus. Pourtant vous avez êtes tous les deux d'accord sur le code à mettre en place.

Peut-être que je ne le place pas au bon endroit ? Je me répète, je suis vraiment débutant donc excusez moi si je fais des erreurs grossières.

Merci encore pour votre aide
0
zipe31 Messages postés 36402 Date d'inscription dimanche 7 novembre 2010 Statut Contributeur Dernière intervention 27 janvier 2021 6 407
24 juin 2014 à 15:27
je n'ai pas trop compris l'explication de zipe31.. notamment le $ cat plop . Il permet de récupérer les données telles que je les ai déjà actuellement ?
Oui. En fait c'est courant ici de créer un fichier nommé plop afin de reproduire les besoins tels qu'ils on été demandés. Et cette commande n'est là que pour te montrer sur quoi j'ai basé ma syntaxe.
0
dubcek Messages postés 18718 Date d'inscription lundi 15 janvier 2007 Statut Contributeur Dernière intervention 22 mars 2024 5 615
Modifié par dubcek le 24/06/2014 à 15:50
affiche le contenu de $RES après le 1er awk
echo "$RES" | cat -A
si le 2ème awk lit dans le fichier, pourquoi echo ${RES} | IFS="µ" read EXP......
0
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014
24 juin 2014 à 16:00
zipe31 : d'accord merci pour ces explications. Mais je ne comprends pas où placer cette instruction. Dois-je y mettre avant le 1er awk ?
0
zipe31 Messages postés 36402 Date d'inscription dimanche 7 novembre 2010 Statut Contributeur Dernière intervention 27 janvier 2021 6 407
24 juin 2014 à 16:02
Non, tu ne dois la mettre nulle part, elle est juste là pour te montrer sur quoi j'ai lancé ma commande.
0
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014
24 juin 2014 à 16:07
Ok mais aprés tu met l'instruction suivante : $ grep -Po '(<|Date: )\K[^>]*' plop
En fait je ne vois pas par quoi remplacer le plop sachant que je ne l'ai pas dans mon code que j'ai mi plus haut.
0
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014
1 juil. 2014 à 15:39
J'ai réussi à avancer concernant ma récupération de données :

Voici le code que j'ai mis en place :

RES=$(awk 'BEGIN {FS = ":"; varFrom = ""; varTo = ""; varDate = ""; flag = 0; vPdeb=0; vPfin=0;}

$1 == "Subject" {flag=0;}

flag == 1 {varTo = varTo $0; vPdeb=index(varTo,"<");vPfin=index(varTo,">"); varTo = substr(varTo,vPdeb+1,vPfin-vPdeb-1); }

$1 == "From" {vPdeb=index($0,"<");vPfin=index($0,">");varFrom = substr($0,vPdeb+1,vPfin-vPdeb-1);}

$1 == "To" {varTo = $0; flag=1;}

$1 == "Date" {vPdeb=index($0,",")+1;vPfin=index($0,"+")-1; varDate = substr($0,vPdeb+1,vPfin-vPdeb-1);}

END {print sprintf("export EXPEDITEUR=%s;export DESTINATAIRE=%s;export DATE_ENVOI=\"%s\"",varFrom,varTo,varDate);}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)

echo "$RES"


Et voici ce que je récupère :


export EXPEDITEUR=pierre.dupont@gmail.fr;export DESTINATAIRE=julien.martin@gmail.fr;export DATE_ENVOI="16 Jun 2014 14:45:08"


Mon problème est désormais de pouvoir récupérer ces données sous cette forme :

EXPEDITEUR=pierre.dupont@gmail.fr;
DESTINATAIRE=julien.martin@gmail.fr;
DATE_ENVOI="16 Jun 2014 14:45:08"


Je ne vois pas trop comment faire cela. Donc si vous avez une idée ?

Merci d'avance
0
zipe31 Messages postés 36402 Date d'inscription dimanche 7 novembre 2010 Statut Contributeur Dernière intervention 27 janvier 2021 6 407
1 juil. 2014 à 16:19
END {printf "EXPEDITEUR=%s;\nDESTINATAIRE=%s;\nDATE_ENVOI=\"%s\"\n",varFrom,varTo,varDate);}'
0
dubcek Messages postés 18718 Date d'inscription lundi 15 janvier 2007 Statut Contributeur Dernière intervention 22 mars 2024 5 615
Modifié par dubcek le 2/07/2014 à 09:05
read EXPEDITEUR DESTINATAIRE DATE_ENVOI <<<$(awk ....
.......
# changer le block END
END {printf "%s %s \"%s\"", varFrom, varTo, varDate}
)
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
ElPibeOro Messages postés 7 Date d'inscription mardi 24 juin 2014 Statut Membre Dernière intervention 7 juillet 2014
7 juil. 2014 à 14:03
J'ai réussi à récupérer ce que je souhaitais, voilà mon code :


 read EXPEDITEUR <<<$(awk -F "[<> ]" '/^From:/ {print $(NF-1)} ' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)

DESTINATAIRE=$(awk 'BEGIN {FS = ":"; varTo = ""; flag = 0;}
$1 == "Subject" {flag=0;}
flag == 1 {vPdeb=index($0,"<");vPfin=index($0,">"); varTo = varTo ";" substr($0,vPdeb+1,vPfin-vPdeb-1) ";";}
$1 == "To" {vPdeb=index($0,"<");vPfin=index($0,">"); varTo = substr($0,vPdeb+1,vPfin-vPdeb-1); flag=1;}
END {print varTo;}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)

DATE_ENVOI=$(awk 'BEGIN {FS = ":"; varDate = ""; flag = 0; vPdeb=0; vPfin=0;}
$1 == "Date" {vPdeb=index($0,",")+1;vPfin=index($0,"+")-1; varDate = substr($0,vPdeb+1,vPfin-vPdeb-1);}
END {print sprintf("export DATE_ENVOI=\"%s\"",varDate);}' ${SAVAGE_HOME}/fichiers/SAV_AGENCE__91bc915d93b2803546aaf344ace9527cc9e3c06f5b7a1d2b19adeaf02893d01b.txt)
eval "$DATE_ENVOI"

echo "EXPEDITEUR=${EXPEDITEUR}"
echo "DESTINATAIRE=${DESTINATAIRE}"
echo "DATE_ENVOI=${DATE_ENVOI}"

et voici ce que je récupère :


EXPEDITEUR=pierre.dupont@gmail.fr
DESTINATAIRE=julien.martin@gmail.fr
DATE_ENVOI=16 Jun 2014 14:45:08

Le problème que je rencontre désormais est que j'aimerai intégrer ces résultats dans 3 variables VarFrom, VarTo, et VarDate.

J'ai essayé avec ce code mais ça ne fonctionne pas...

varFrom=$(EXPEDITEUR)
varTo=$(DESTINATAIRE)
varDate=$(DATE_ENVOI)

Merci d'avance pour votre aide
0