![]() |
| Le forum de référence en programmation et développement. Articles, cours et tutoriels du débutant au chef de projet et DBA confirmé. | |||||||
|
|||||||
| Shell Vos questions sur l'utilisation des commandes shell |
![]() |
|
|
Outils de la discussion |
|
|
#1 (permalink) |
|
Invité de passage
![]() Date d'inscription: juillet 2008
Messages: 2
|
Bonjour,
Je dois supprimer deux colonnes d'un fichier avec séparateur mais avant je dois copier une colonne dans une autre suivant un double test ! Détail : j'ai un fichier avec la "virgule" comme séparateur. ce fichier comporte 10 colonnes SI le contenu de la colonne 6 a plus de 4 caractères (alphanumériques) et la colonne 8 est différent de "N/A" ALORS copier le contenu de la colonne 8 dans la colonne 6 APRES et pour TOUTE Supprimer les colonnes 7 et 8. J'ai déjà fait la suppression des colonnes avec : cat $SOURCE |cut -d , -f 1-6,9- >$DESTINATION Mais ça ne passe pas pour les copies de colonnes. J'ai essayé avec 'awk' mais je bloque. Merci d'avance pour votre aide précieuse. Gerard |
|
|
|
|
|
#2 (permalink) |
|
Membre éprouvé
![]() Date d'inscription: mars 2007
Localisation: Toulouse
Messages: 471
|
Le script est fait à 99%, je te laisse faire le 1%
http://lea-linux.org/cached/index/Dev-awk.html http://www.shellunix.com/awk.html Code :
awk -F"," '
{
if ( length($6) > 4 && $8 != "N/A") {
$6 = $8
}
print $1","$2". etc..."
} ' test.txt > result.txt
__________________
Loi de Murphy: La Théorie c'est quand ça ne marche pas mais que l'on sait pourquoi. La Pratique c'est quand ça marche mais qu'on ne sait pas pourquoi. Quand la théorie rejoint la pratique ça ne marche pas et on ne sait pas pourquoi. |
|
|
|
|
|
#3 (permalink) |
|
Invité de passage
![]() Date d'inscription: juillet 2008
Messages: 2
|
Merci beaucoup pour ta réponse.
Je l'ai reprise, adapté : - OFS pour conserver le séparateur dans le fichier de sortie - Test pour la 1ere ligne de commentaire et il me reste un petit problème. Plutôt que de faire print $1","$2"," .... j'ai ajouté le séparateur de sortie, vider les 2 champs à supprimer et lancé un print de la ligne $0 ==> Seulement, les champs $7 et $8 sont bien vides mais j'ai quand même les séparateur ... ce qui me donne $1,$2,$3,$4,$5,$6,,,$9,$10,$2,... au lieu de $1,$2,$3,$4,$5,$6,$9,$10,$2,... souhaité. J'ai oublié, j'ai 29 champs et je voulais optimisé un print $1","$2"," .... $29"," Je suis à l'écoute pour une optimisation Encore merci Code :
awk '
BEGIN { FS="," ; OFS=","}
{
if ( $1 != "texte_1ere_ligne" && length($6) > 4 && $8 != "N/A")
{
$6 = $8
}
$7 = "" ;
$8 = "" ;
print $0
} ' source.txt > result.txt
Dernière modification par gangsoleil ; 17/07/2008 à 15h26 |
|
|
|
![]() |
![]() |
||
awk / cut : Comment copier des colonnes avec des tests
|
||
| Outils de la discussion | |
|
|