Forum des développeurs  

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é.
Précédent   Forum des développeurs > Hardware, Systèmes et Logiciels > Linux > Applications > Shell

Shell Vos questions sur l'utilisation des commandes shell

Réponse
 
Outils de la discussion
Vieux 15/07/2008, 16h25   #1 (permalink)
Invité de passage
 
Date d'inscription: juillet 2008
Messages: 2
Par défaut awk / cut : Comment copier des colonnes avec des tests

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
drareg06 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 15/07/2008, 20h21   #2 (permalink)
Membre éprouvé
 
Avatar de BlaireauOne
 
Date d'inscription: mars 2007
Localisation: Toulouse
Messages: 471
Par défaut

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.
BlaireauOne est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 16/07/2008, 11h49   #3 (permalink)
Invité de passage
 
Date d'inscription: juillet 2008
Messages: 2
Par défaut

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
drareg06 est déconnecté   Envoyer un message privé Réponse avec citation
Réponse

Précédent   Forum des développeurs > Hardware, Systèmes et Logiciels > Linux > Applications > Shell



Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are non
Pingbacks are non
Refbacks are non
Navigation rapide


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


Publiez vos articles, tutoriels et cours et rejoignez-nous dans l'équipe de rédaction du club d'entraide des développeurs francophones. Nous contacter
Copyright 2000-2008 www.developpez.com - Legal informations