Re: [HS] sed : garder le motif
Salut et merci pour vos réponses.
> steve a écrit :
>> Bonjour et pardon pour ce HS.
>
> Tu peux essayer la liste shellscript pour ça ;-) (http://debianworld.org/shellscript-fr)
Oui, et en plus j'y suis inscrit ...
>> J'ai un long fichier de la forme
>>
>> ABC(du texte)
>> MSD(un autre texte)
>> etc...
>>
>> J'aimerai traiter ce fichier de tel manière qu'à la sortie je n'ai que
>> les 3 premiers caractères :
>>
>> ABC
>> MSD
>> etc...
>>
>> Sed devrait faire l'affaire non ?
>
> Oui.
> Pour ajouter à ce qu'on dit les autres, on peut utiliser l'option -r pour avoir les regex étendue et ne plus avoir besoin d'échapper les () et {}.
>
> Ensuite, si tu veux ne pas afficher les lignes qui ne correspondent pas au pattern
>
> $ echo 'ABCbla bla
> DEFblabla
> GhIblabla'|sed -rne 's/^([A-Z]{3}).*$/\1/p'
> ABC
> DEF
Chez moi, rien ne s'affiche :
$ cat file.csv | sed -rne 's/^([A-Z]{3}).*$/\1/'
$
et pourtant le fichier commence par
ABC(ABCYMO)
BAR(BARDO)
> le -n, c'est pour ne pas afficher les lignes par défaut, d'où le besoin
> de préciser le p à la fin de l'expression (on décide un print explicite).
> Si tu veux la ligne qui ne correspond pas au pattern, c'est
> $ echo 'ABCbla bla
> DEFblabla
> GhIblabla'|sed -re 's/^([A-Z]{3}).*$/\1/'
> ABC
> DEF
> GhIblabla
Par contre sans le n le résultat attendu s'affiche.
Merci.
Reply to: