logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
utilisateurs:hypathie:tutos:accueil [15/07/2014 12:30]
Hypathie [Synthèse sed]
utilisateurs:hypathie:tutos:accueil [19/07/2014 09:16]
Hypathie [Synthèse grep]
Ligne 6: Ligne 6:
   * Débutant, à savoir : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-)   * Débutant, à savoir : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-)
  
-===== Synthèse sur cut ===== 
-Soit les trois dernières lignes du fichier /etc/passwd : 
-<code user> 
-cat /etc/passwd 
-</​code>​ 
-<​code>​ 
-Debian-gdm:​x:​112:​120:​Gnome Display Manager:/​var/​lib/​gdm3:/​bin/​false 
-hypathie:​x:​1000:​1000:​Hypathie,,,:/​home/​hypathie:/​bin/​bash 
-libvirt-qemu:​x:​113:​122:​Libvirt Qemu,,,:/​var/​lib/​libvirt:/​bin/​false 
-</​code>​ 
-  * Un __champ__ est une chaîne de caractères\\ Par exemple, la dernière ligne ci-dessus est composée de sept champs; ''​libvirt-qemu''​ ; ''​x''​ ; ''​113'',​ etc.  
-  * Un __délimiteur__ est ce qui sépare chaque champ\\ ci-dessus c'est '':''​. 
  
-==== Introduction ==== 
-La commande cut permet d'​afficher des zones spécifiques d'un fichier. 
  
-<​code>​ 
-cut [options] [fichier...] 
-</​code>​ 
-====option -c==== 
-Sélection par caractère. 
-===Exemples=== 
-> Le premier caractère des trois dernières lignes 
-<code user> 
-cut -c 1 /etc/passwd 
-</​code>​ 
-<​code>​ 
-D 
-h 
-l 
-</​code>​ 
- 
->Du premier au neuvième caractère 
-<code user> 
-cut -c -9 /etc/passwd 
-</​code>​ 
-<​code>​ 
-Debian-gd 
-hypathie: 
-libvirt-q 
-</​code>​ 
- 
->Du neuvième au dernier caractère 
-<code user> 
-cut -c 9- /etc/passwd 
-</​code>​ 
-<​code>​ 
-dm:​x:​112:​120:​Gnome Display Manager:/​var/​lib/​gdm3:/​bin/​false 
-:​x:​1000:​1000:​Hypathie,,,:/​home/​hypathie:/​bin/​bash 
-qemu:​x:​113:​122:​Libvirt Qemu,,,:/​var/​lib/​libvirt:/​bin/​false 
-</​code>​ 
- 
-> Du onzième au vingt-et-unième caractère 
-<code user> 
-cut -c 11-21 /etc/passwd 
-</​code>​ 
-<​code>​ 
-:x:112:120: 
-:1000:1000: 
-mu:x:113:12 
-</​code>​ 
- 
-<code user> 
-cut -c 1-9,11-21 /etc/passwd 
-</​code>​ 
-<​code>​ 
-saned:​x:​11:​119::/​hom 
-Debian-gd:​x:​112:​120:​ 
-hypathie::​1000:​1000:​ 
-libvirt-qmu:​x:​113:​12 
-</​code>​ 
-===À savoir === 
-^Découpages par caractère ​ ^ significations ​      ^ 
-|cut -c ''​-n'' ​            |du caractère 1 à n    | 
-|cut -c ''​n-'' ​            |de n jusqu'​à la fin   | 
-|cut -c ''​n-m'' ​           |de n à m              | 
-|cut -c ''​n-m,​i-j'' ​       | de n à m et de i à j | 
- 
-====Options -d et -f==== 
-Découpage par champ (ou colonne), en fonction du délimiteur ''​-d''​ 
-Et liste des champs ""​-f""​. 
-<note tip> 
-À savoir.\\ 
-Par défaut, le délimiteur est la tabulation.\\ 
-Si dans le fichier à traiter le séparateur est la tabulation, on n'a pas à indiquer l'​option ''​-d'',​ mais si le séparateur est un autre caractère, il faut l'​indiquer 
-</​note>​ 
-===Exemples=== 
- 
->Coupe en fonction du délimiteur ''​ -d':'​ ''​ et du premier champ ''​-f 1''​ 
-<code user> 
-cut -d':'​ -f 1 /etc/passwd 
-</​code>​ 
-<​code>​ 
-Debian-gdm 
-hypathie 
-libvirt-qemu 
-</​code>​ 
- 
->Coupe en fonction du délimiteur ''​ -d':'​ ''​ et des champs 1 ; 3 et 4 ''​-f 1,​3,​4''​. 
-<code user> 
-cut -d':'​ -f 1,3,4 /etc/passwd 
-</​code>​ 
- 
-<​code>​ 
-Debian-gdm:​112:​120 
-hypathie:​1000:​1000 
-libvirt-qemu:​113:​122 
-</​code>​ 
- 
-===À savoir=== 
-^                            ^                                 ^ 
-|cut -d'​délimiteur'​ -f n     | délimiteur et n° champ délimité | 
-|cut -d'​délimiteur'​ f n,m,...| délimiteur et plusieurs champs ​ | 
- 
-==== wc ==== 
-Afficher soit le nombre de mots, soit le nombre de ligne, soit le nombre d'​octets 
-<​code>​ 
-wc [options] [fichier...] 
-</​code>​ 
-=== Option -l : Afficher les lignes === 
->Le nombre d'​utilisateur du système ? 
-<code user> 
-wc -l /etc/passwd 
-</​code>​ 
-<​code>​ 
-33 /etc/passwd 
-</​code>​ 
- 
-===Option -w : le nombre de mots=== 
-<code user> 
-echo "​Coucou à tous">>​ essai-wc 
-</​code>​ 
-<code user> 
-wc -w essai-wc 
-</​code>​ 
-<​code>​ 
-3 essai-wc 
-</​code>​ 
- 
-=== Options -c : nombre d'​octet(s)=== 
-<code user> 
-wc -c essai-wc 
-</​code>​ 
-<​code>​ 
-15 essai-wc 
-</​code>​ 
- 
-=====Synthèse ​ grep ===== 
-<​code>​ 
-grep [options] regexp [fichier...] 
-</​code>​ 
- 
-Voir : [[atelier:​chantier:​bash-vii-globs-etendus-regex#​tableau-des-caracteres-utilises-dans-les-expressions-regulieres-etendues|caractères utilisés dans les expressions régulières étendues]] 
- 
-^       ​^ ​                                               ^ 
-|''​-c''​ |afficher le décompte des lignes correspondantes | 
-|''​-i''​ | ignorer la case  | 
-|''​-E''​ |utiliser les regexp étendues\\ (correspond à egrep) ​ | 
- 
-> Deux utilisations:​\\ 
->Soit ''​grep [options] "​expression"​ /​chemin/​fichier''​ (on applique grep sur un fichier) 
->Soit ''​grep [options] cmd | regexp''​ (on travaille à partir d'un flux d'​entrée avec un filtre (pipe)\\ 
- 
- 
-===Sur un fichier=== 
-<code user> 
-grep -E "​(:​[0-9]{4}:​){1}"​ /etc/passwd 
-</​code>​ 
-<​code>​ 
-hypathie:​x:​1000:​1000:​Hypathie,,,:/​home/​hypathie:/​bin/​bash 
-</​code>​ 
- 
-===Filtre un flux d'​entrée === 
-<code user> 
-/​sbin/​ifconfig | grep -oE "​[0-9]{1,​3}\.[0-9]{1,​3}\.[0-9]{1,​3}\.[0-9]{1,​3}"​ 
-</​code>​ 
-<​code>​ 
-127.0.0.1 
-255.0.0.0 
-192.168.0.21 
-192.168.0.255 
-255.255.255.0 
-</​code>​ 
 =====Synthèse sed ===== =====Synthèse sed =====
 ===Syntaxe=== ===Syntaxe===
Ligne 202: Ligne 21:
 ^options ^significations ^ ^options ^significations ^
 | ''​-e''​ | enchaîner plusieurs commandes | | ''​-e''​ | enchaîner plusieurs commandes |
-| ''​-r''​ | utiliser les expressions régulières étendues |+| ''​-r''​ | utiliser les expressions régulières étendues ​dans un script ​|
 |''​-n''​ |mode silencieux : permet de ne rien modifier\\ associée au drapeau p (print) : affichage sur la sortie standard | |''​-n''​ |mode silencieux : permet de ne rien modifier\\ associée au drapeau p (print) : affichage sur la sortie standard |
 |''​-f''​ |Les commandes sont lues à partir d'un fichier préalablement rédigé. | |''​-f''​ |Les commandes sont lues à partir d'un fichier préalablement rédigé. |
 |''​-i''​ |Le fichier est édité sur place.| |''​-i''​ |Le fichier est édité sur place.|
  
-=== Option -et préparation===+====Afficher ou modifier un fichier ==== 
 +>Dans les exemples qui suivent, ne considérons que la présence ou l'​absence de l'​option ''​i'';​ le reste de la commande est expliqué par la suite. 
 +===sed permet d'​afficher sur la sortie standard===
   * Créer un fichier :   * Créer un fichier :
 <code user> <code user>
 echo "aaaa BBB cCcC # 12345" >> ~/​sed1.txt ​ echo "aaaa BBB cCcC # 12345" >> ~/​sed1.txt ​
 </​code>​ </​code>​
-  ​sans ''​-i'' ​afficher ​le résultat de sed sans modification : + 
 +  ​Afficher le contenu d'un fichier :  
 +<code user> 
 +sed '' ​sed1.txt 
 +</​code>​ 
 +<​code>​ 
 +aaaa BBB cCcC # 12345 
 +</​code>​ 
 +===sed permet d'​afficher ​sa modification ​(sans modifier le fichier)=== 
 +  * remplacer les espaces par des retours à la ligne :
 <code user> <code user>
 sed 's+ +\n+g' ~/sed1.txt sed 's+ +\n+g' ~/sed1.txt
Ligne 223: Ligne 53:
 12345  12345 
 </​code>​ </​code>​
-  ​* sauvegarder ​un fichier ​''​sed -i.bak''​ :+ 
 +<code user> 
 +sed ''​ sed1.txt 
 +</​code>​ 
 +<​code>​ 
 +aaaa BBB cCcC # 12345 
 +</​code>​ 
 +=== Option -i : modifier le fichier === 
 + 
 +  ​* sauvegarder ​le fichier ​d'​origine "​sed1.txt"​ avec ''​sed -i.bak''​ :
 <code user> <code user>
 sed -i.bak '​s/​sed1.txt//'​ ~/sed1.txt sed -i.bak '​s/​sed1.txt//'​ ~/sed1.txt
 </​code>​ </​code>​
 +>sed n'a pas afficher sur la sortie standard le contenu du fichier de sauvegarde.
 <code user> <code user>
 cat sed1.txt.bak cat sed1.txt.bak
Ligne 235: Ligne 75:
   * modifier un fichier avec ''​sed -i''​ :   * modifier un fichier avec ''​sed -i''​ :
 <code user> <code user>
-sed -i 's+ +\n+g' ~/​sed1.txt ​&& cat ~/sed1.txt+sed -i 's+ +\n+g' ~/sed1.txt 
 +</code> 
 +<code user> 
 +cat sed1.txt
 </​code>​ </​code>​
 <​code>​ <​code>​
Ligne 246: Ligne 89:
 === Plusieurs options à la suite=== === Plusieurs options à la suite===
 >Les options doivent se suivre dans un ordre précis >Les options doivent se suivre dans un ordre précis
 +
   * ajouter des sauts de ligne : ''​sed -i -e '​s/​$/​\\n/'​ ~/​sed1.txt''​   * ajouter des sauts de ligne : ''​sed -i -e '​s/​$/​\\n/'​ ~/​sed1.txt''​
   * supprimer les lignes vides : ''​sed -i -e '/​^$/​d'​ ~/​sed1.txt''​   * supprimer les lignes vides : ''​sed -i -e '/​^$/​d'​ ~/​sed1.txt''​
 +
 ====Adressage==== ====Adressage====
 <code user> <code user>
-sed ''​ ~/sed1.txt.bak  +s/motif/substitut/ ​   
-</code> + -si motif = une regex 
-<code+ -> alors subtitut = une chaîne de caractère
-aaaa BBB cCcC # 12345+
 </​code>​ </​code>​
 +>On peut utiliser la syntaxe habituelle, ou la syntaxe étendue avec l'​option ''​-r''​.
 +
 +<code text info sed>
 +`-r'
 +`--regexp-extended'​
 +     Use extended regular expressions rather than basic regular
 +     ​expressions. ​ Extended regexps are those that `egrep'​ accepts;
 +     they can be clearer because they usually have less backslashes,​
 +     but are a GNU extension and hence scripts that use them are not
 +     ​portable. ​ *Note Extended regular expressions:​ Extended regexps.
 +</​code> ​
 +<​note>​
 +Sed utilise une version particulière des expressions régulières. ​
 +
 +  * Sans l'​option ''​-r''​ :
 +
 +Sed couvre des expressions régulières de base (POSIX). Il s'agit des caractères de bases qui sont communs à tous les programmes utilisant les expressions régulières.\\ En voici un rappel :
 +''​*'',​ '','',​ ''​^'', ​ ''​$'',​ ''​[ ]'',​ ''​[^ ]'',​ ''​\( \)'',​ ''​\n'',​ ''​\{n\}'',​ ''​\{n,​m\}'',​ ''​\{n,​\}''​.
 +
 +  * avec ''​-r''​ : 
 +
 +Il s'y ajoute les caractères POSIX étendus :\\
 +''​|''​ ; ''​^''​ ; ''​$''​ ; ''​.''​ ; ''​*''​ ; ''​+''​ ; ''?''​ ; ''​( ​  ​)''​ ; ''​[''​ ; ''​{ ​  ​}''​ ; ''​\''​ ; ''​[:​alpha:​]'',​ ''​[:​blank:​]'',​ ''​[:​cntrl:​]'',​ ''​[:​digit:​]'',​ ''​[:​graph:​]'',​ ''​[:​lower:​]'',​ ''​[:​print:​]'',​ ''​[:​punct:​]'',​ ''​[:​space:​]'',​ ''​[:​upper:​]'',​ ''​[:​xdigit:​]''​\\ ​
 +Pour résumer, tous les caractères de ce tableau fonctionnent avec ''​sed -r''​ : [[atelier:​chantier:​bash-vii-globs-etendus-regex#​tableau-des-caracteres-utilises-dans-les-expressions-regulieres-etendues]]
 +
 +Il s'y ajoute enfin quelques un caractères que l'on retrouve sous Perl :\\
 +''​\b'',​ ''​\B'',​ ''​\w'',​ ''​\W'',​ ''​\s'',​ ''​\S'',​ ''​\`'',​ ''​\''',​ ''​\<'',​ ''​\>''​
 +
 +Ainsi que :
 + ''​\a''​ (caractère alerte), ''​\f''​ (saut), ''​\n''​ (saut de ligne), ''​\r''​ (retour chariot), ''​\''​t (tabulation horizontale),​ ''​\v''​ (tabulation verticale), ''​\cx''​ (Control-x ), ''​\dxxx''​ (caractère en valeur ascii décimal), ''​\OXXX''​ (caractère par valeur aSCII octal), ''​\xhh''​ (caractère par valeur aSCII hexadécimal).
 +</​note>​
 === Syntaxe d'​adressage avec exemple la commande de suppression === === Syntaxe d'​adressage avec exemple la commande de suppression ===
   * ''​d''​ commande de suppression   * ''​d''​ commande de suppression

Pied de page des forums

Propulsé par FluxBB