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 [18/07/2014 11:03]
Hypathie [Synthèse grep]
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) ​ | 
-|''​-o''​ |afficher uniquement les parties (non vides) correspondantes des lignes sélectionnées,​ chaque partie étant affichée sur une ligne séparée.| 
- 
- 
-> 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 -E "​[0-9]{1,​3}\.[0-9]{1,​3}\.[0-9]{1,​3}\.[0-9]{1,​3}"​ 
-</​code>​ 
-<​code>​ 
-          inet adr:​192.168.0.22 ​ Bcast:​192.168.0.255 ​ Masque:​255.255.255.0 
-          inet adr:​127.0.0.1 ​ Masque:​255.0.0.0 
-</​code>​ 
-<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>​ 
- 
-<note tip> 
-Attention de ne pas oublier ''​-o''​ pour afficher l'​occurrence exacte d'un mot au lieu de la ligne entière où figure l'​occurrence du mot ! 
-</​note>​ 
-<code user> 
-echo "bfer aaa jhgao aaaaaa haug aaaaaaaa"​ | grep -E "​[[:​blank:​]][a]{3}[[:​blank:​]]"​ 
-</​code>​ 
-<​code>​ 
-bfer aaa jhgao aaaaaa haug aaaaaaaa 
-</​code>​ 
- 
-<code user> 
-echo "bfer aaa jhgao aaaaaa haug aaaaaaaa"​ | grep -oE "​[[:​blank:​]][a]{3}[[:​blank:​]]"​ 
-</​code>​ 
-<​code>​ 
- aaa 
-</​code>​ 
 =====Synthèse sed ===== =====Synthèse sed =====
 ===Syntaxe=== ===Syntaxe===
Ligne 307: Ligne 100:
 </​code>​ </​code>​
 >On peut utiliser la syntaxe habituelle, ou la syntaxe étendue avec l'​option ''​-r''​. >On peut utiliser la syntaxe habituelle, ou la syntaxe étendue avec l'​option ''​-r''​.
-<code text man sed> 
-  -r, --regexp-extended 
  
-              use extended regular expressions in the script. 
- //​[...]//​ 
-REGULAR EXPRESSIONS 
-       ​POSIX.2 BREs should be supported, but they aren't completely because of 
-       ​performance problems. ​ The \n sequence in a regular expression ​ matches 
-       the newline character, and similarly for \a, \t, and other sequences. 
-</​code>​ 
 <code text info sed> <code text info sed>
 `-r' `-r'
Ligne 327: Ligne 111:
 </​code> ​ </​code> ​
 <​note>​ <​note>​
-  ​sans ''​-r''​ : +Sed utilise une version particulière des expressions régulières.  
-//ER// simples ​ ''​^'' ​ ''​$'' ​;  ​''​.'' ​;  ​''​*'' ​''​\( ​  ​\)'' ​''​['' ​''​\{ ​  ​\}'' ​''​\''​+ 
 +  ​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''​ :    * avec ''​-r''​ : 
  
-//ER// étendues ​: ''​|''​ ; ''​^''​ ; ''​$''​ ; ''​.''​ ; ''​*''​ ; ''​+''​ ; ''?''​ ; ''​( ​  ​)''​ ; ''​[''​ ; ''​{ ​  ​}''​ ; ''​\''​ ; ''​[bracket-expression]'' ​+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>​ </​note>​
 === Syntaxe d'​adressage avec exemple la commande de suppression === === Syntaxe d'​adressage avec exemple la commande de suppression ===

Pied de page des forums

Propulsé par FluxBB