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:erb-et-ere-par-le-contexte-des-commandes [13/08/2014 15:54]
Hypathie [Caractères spécifiques aux ERb]
utilisateurs:hypathie:tutos:erb-et-ere-par-le-contexte-des-commandes [13/08/2014 17:31]
Hypathie [grep, sed, find, locate et les caractères spécifiques aux ERb]
Ligne 687: Ligne 687:
  
  
-=====Caractères spécifiques aux ERb  =====+=====Caractères spécifiques aux ERb et ERe ===== 
 + 
 +<note tip> 
 +Je présenterai ici les commandes qui utilisent uniquement les ERb, c'​est-à-dire,​ celles qui n'ont pas besoin d'une option pour utiliser les expressions rationnelles et qui n'​utilisent que les expressions rationnelles basiques, et donc forcément les caractères spécifiques aux ERb.\\  
 +Il s'agit de **''​expr''​** et **''​vi''​**.\\  
 + 
 +Elles utilisent bien sûr tous [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-communs-aux-erb-et-ere|les caractères communs aux ERb et ERe]], leur utilisation avec ces caractères apparaîtra en à côté de l'​utilisation des caractères spécifiques aux ERb qui permettent de décrire des motifs plus complexes. 
 + 
 +Pour les commandes "à option"​ qui utilisent tous les caractères spécifiques aux ERb, mais qui peuvent aussi utiliser ces mêmes caractères((parenthèses,​ accolades, +, ? et |)) sans antislash avec les ERe, je présenterai rapidement leur utilisation des ERb dans le chapitre sur les caractères spécifiques aux ERe.  
 +</​note>​ 
 + 
 +====Caractères spécifiques aux ERb ==== 
 Toutes les commandes utilisant les expressions rationnelles basiques utilisent les caractères énumérés ci-dessous.\\ Toutes les commandes utilisant les expressions rationnelles basiques utilisent les caractères énumérés ci-dessous.\\
    
Ligne 700: Ligne 712:
  
 Les commandes **''​grep''​** (ou **''​grep -G''​**) ; **''​find -regextype "​posix-basic"​ ''​** ;  Les commandes **''​grep''​** (ou **''​grep -G''​**) ; **''​find -regextype "​posix-basic"​ ''​** ; 
-**''​locate --regexp''​** ; **''​sed''​**;​ **''​vi''​** utilisent en plus ces caractères-ci :+**''​locate --regexp''​** ; **''​sed''​**;​ **''​vi''​** utilisent en plus ces caractères ci-dessous ​:
  
 ^                            ^                                      ^ ^                            ^                                      ^
Ligne 710: Ligne 722:
 Mais il permet de rendre littéraux les autres caractères des ERb, par exemple ''​\.''​ permet de sélectionner un point. Mais il permet de rendre littéraux les autres caractères des ERb, par exemple ''​\.''​ permet de sélectionner un point.
  
-<note tip> 
-Je présenterai principalement les commandes qui n'​utilisent que les ERb, c'​est-à-dire,​ celles qui n'ont pas besoin d'une option pour utiliser les expressions rationnelles et qui n'ont pas encore été abordées, **''​expr''​** et **''​vi''​**.\\ ​ 
  
-Elles utilisent bien sûr tous [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-communs-aux-erb-et-ere|les caractères communs aux ERb et ERe]], leur utilisation avec ces caractères apparaîtra en à côté de l'​utilisation des caractères spécifiques aux ERb.+====Caractères spécifiques ​aux ERe ====
  
-Je ferai ensuite un bref rappel des commandes "à option" ​qui utilisent ​tous les caractères ​spécifiques ​aux ERb, mais qui peuvent aussi utiliser ​ces mêmes caractères((parenthèses,​ accolades, ​+, et |)) sans antislash avec les ERe+Les caractères spécifiques aux ERe sont utilisables avec les commandes ​
-</note>+ 
 +**''​grep -E''​** ; (ou **''​egrep''​**) ; **''​find -regextype ​"posix-extended" ​''​** ;  
 +**''​locate --regex''​** ; **''​sed -r''​** et **''​awk''​**((alias gawk)).\\  
 + 
 +Bien évidemment ​tous [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-communs-aux-erb-et-ere|les caractères ​communs ​aux ERb et ERe]] sont utilisables avec ces commandes et ces options. 
 + 
 +^expressions ​               ^ Modèles reconnus ​            ^ 
 +|**''?''​** | zéro ou une fois le caractère ou le regroupement précédent | 
 +|**''​+''​** |une à n fois le caractère ou regroupement précédent | 
 +|**''<​nowiki>​{m}</​nowiki>''​** |m fois le caractère précédent | 
 +|**''<​nowiki>​{m,}</​nowiki>''​** | m fois le caractère précédent | 
 +|**''<​nowiki>​{m,​n}</​nowiki>''​** | entre m et n fois le caractère précédent ​| 
 +|**''<​nowiki>​( er1)</​nowiki>''​** | regroupement | 
 +|**''<​nowiki>​er1|er2|er3</​nowiki>''​** | alternative | 
 +|**''<​nowiki>​(er)+</​nowiki>''​**|Une ou plus de une chaîne(s) consécutive(s) validée(s) "​er"​.| 
 +|**''<​nowiki>​(er)*</​nowiki>''​**|zéro ou plus de zéro chaîne(s) consécutive(s) validée(s) par "​er"​ | 
 +|**''<​nowiki>​(er)?</​nowiki>''​**|une chaîne bulle ou toute chaîne validée par "​er"​.| 
 +|**''<​nowiki>​[c1c2...]</​nowiki>''​**|Tout caractère expressément listé entre les crochets.| 
 +|**''<​nowiki>​[^c1c2...]</nowiki>''​**|Tout caractère excepté ceux qui sont expressément listés entre les crochets.| 
 +|**''<​nowiki>​[c1-c2]</​nowiki>''​**|Tout caractère appartenant à l’intervalle c1 c2, bornes comprises.| 
 +|**''<​nowiki>​er1|er2</​nowiki>''​**|Toute chaîne de caractères validée soit par er1 soit par er2.| 
 +|**''<​nowiki>​(er)(er)</​nowiki>''​**|Toute chaîne validée par l’expression er, chaîne vide exclue.| 
 +|**''<​nowiki>​(er1)(er2)</​nowiki>''​**|Toute chaîne de caractères de type AB, dans laquelle l’expression régulière er1 valide A et l’expression régulière er2 valide B.\\ Avec awk uniquement| 
 + 
 +=====Les commandes expr et vi et les caractères spécifiques aux ERb =====
  
 ====La commande expr n'​utilise que ERb==== ====La commande expr n'​utilise que ERb====
Ligne 794: Ligne 828:
  
 > Le chiffre "​1"​ est le code de retour. > Le chiffre "​1"​ est le code de retour.
- 
  
   * sous chaîne avec caractère fin de mot :   * sous chaîne avec caractère fin de mot :
Ligne 986: Ligne 1019:
 </​note>​ </​note>​
  
-===== grep, sed, find, locate et les caractères spécifiques aux ERb =====+===== grep, sed, find, locate, awk et les caractères spécifiques aux ERe  ​=====
  
-Les commandes **''​grep''​** et **''​sed''​**,​ les commandes **''​locate --regexp''​** et **''​find -regextype “posix-basic”''​** utilisent tous les caractères spécifiques aux ERb.\\ Voir leur utilisation avec [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-des-ere|les expressions rationnelles étendues]].+===Préparation===
  
-  * Rappel du fichier "<​nowiki>​liste4-spec</​nowiki>":​+  * Soit le fichier "<​nowiki>​liste4-spec</​nowiki>":​
 <​code>​ <​code>​
 gdd:​a:​aa:​aaa:​aaaa:​aaaaaa:​aaaaaaaa gdd:​a:​aa:​aaa:​aaaa:​aaaaaa:​aaaaaaaa
Ligne 1009: Ligne 1042:
 </​code>​ </​code>​
  
-==== grep ou grep -et les caractères spécifiques aux ERb====+==== grep -E (egrep) ​et les caractères spécifiques aux ERe==== 
 +Avec l'​option -E grep utilisent les expressions rationnelles étendues.\\  
 +La commande egrep et un équivalent.
  
-  * les accolades ​avec antislash (le caractère précédent un nombre exact de fois) :+<note tip> 
 +Pour les caractères : **''​ <​nowiki>​[</​nowiki> ​ <​nowiki>​]</​nowiki>​ <​nowiki>​{</​nowiki>​ <​nowiki>​}</​nowiki>​ ?  +  |''​**\\  
 + 
 +il possible ​avec grep d'​utiliser aussi les caractères spécifiques aux ERb.\\  
 +Par exemple ​:\\ 
 <code user>​grep "​1A\{3\}\.A\{3\}\..*"​ liste4-spec</​code>​ <code user>​grep "​1A\{3\}\.A\{3\}\..*"​ liste4-spec</​code>​
 +ou
 +
 +<code user>​grep -G "​1A\{3\}\.A\{3\}\..*"​ liste4-spec</​code>​
 +
 <​code>​ <​code>​
 7 1AAA.AAA.bcdef aBcd6a 123* 7 1AAA.AAA.bcdef aBcd6a 123*
 </​code>​ </​code>​
  
-  * mais on peut utiliser le caractère ​\+ : +-> mais ne pas oublier l'​antislash devant les accolades !\ 
-<code user>​grep "\(1A\{3\}\.\)\+.*" liste4-spec</​code>​+</​note>​ 
 + 
 +===Parenthèses === 
 + 
 +<code user>​grep ​-E "​( ​[0-9]{4})" liste4-spec</​code>​
 <​code>​ <​code>​
-7 1AAA.AAA.bcdef aBcd6a 123*+-15 +36 5687 {15} exemple{36}
 </​code>​ </​code>​
  
- +===le caractère précédent de "​n"​ à "​m"​ fois :=== 
-  * le caractère précédent de "​n"​ à "​m"​ fois : +<code user>​grep ​-E "​[0-9]{1,​3}"​ liste4-spec</​code>​
-<code user>​grep "[0-9]\{1,3\}" liste4-spec</​code>​+
 <​code>​ <​code>​
 T5c Kc5 T5 c E2* abcd 7 9Abcd T5c Kc5 T5 c E2* abcd 7 9Abcd
Ligne 1031: Ligne 1077:
 abc2356.99 abc2356.99
 73000|Savoie 73000|Savoie
 +123456
 +1234567
 index-tel|04|Rhône-Alpe index-tel|04|Rhône-Alpe
 -15 +36 5687 {15} exemple{36} -15 +36 5687 {15} exemple{36}
Ligne 1036: Ligne 1084:
 </​code>​ </​code>​
  
-  * le caractère précédent au moins "​n"​ fois : +===Les accolades (le caractère précédent un nombre exact de fois) : === 
-<code user>​grep "[0-9]\{4,\}" liste4-spec</​code>​+<code user>​grep -E "​1A{3}\.A{3}\..*"​ liste4-spec</​code>​ 
 +<​code>​ 
 +7 1AAA.AAA.bcdef aBcd6a 123* 
 +</​code>​ 
 + 
 +===Le caractère précédent au moins "​n"​ fois :=== 
 +<code user>​grep ​-E "​[0-9]{4,​}"​ liste4-spec</​code>​
 <​code>​ <​code>​
 abc2356.99 abc2356.99
Ligne 1045: Ligne 1099:
 </​code>​ </​code>​
  
-  * parenthèses avec antislash ​et mémorisation :+===Le caractère + et parenthèses ===
  
-<code user>​grep "\[0-9]\{4\}\)" liste4-spec</​code>​+<code user>​grep ​-E "(1A{3}\.)+.*" liste4-spec</​code>​
 <​code>​ <​code>​
--15 +36 5687 {15} exemple{36}+7 1AAA.AAA.bcdef aBcd6a 123*
 </​code>​ </​code>​
  
-  * Le caractère ​\: +===Le caractère ? === 
-<code user>​grep "trucs\?" liste4-spec</​code>​+<code user>​grep ​-E "​trucs?"​ liste4-spec</​code>​
 <​code>​ <​code>​
 il y a un truc et un truc et encore un truc et une chose il y a un truc et un truc et encore un truc et une chose
Ligne 1063: Ligne 1117:
 >On cherche les lignes qui comporte "​truc"​ au singulier ou au pluriel. >On cherche les lignes qui comporte "​truc"​ au singulier ou au pluriel.
  
-====sed et les caractères spécifiques aux ERb ====+===Le caractère d'​alternative | === 
 +<code user>​grep -E "​(truc|chose)"​ liste4-spec</​code>​ 
 +<​code>​  
 +il y a un truc et un truc et encore un truc et une chose 
 +choses et trucs ne font pas bon ménage 
 +trucschosetruc 
 +tructructrucs 
 +chosechosechose 
 +</​code>​ 
 + 
 +====sed et les caractères spécifiques aux ERe ====
 __**Rappel**__\\ ​ __**Rappel**__\\ ​
  
 Par défaut sed utilise les ERb.\\ ​ Par défaut sed utilise les ERb.\\ ​
-La syntaxe est la même que pour les caractères ​communs aux ERe.+Pour s'​éviter de mettre un antislash devant parenthèse,​ accolade, ?, +, |,\\ il faut utiliser **l'​option -r**.\\  
 + 
 +Sans option et avec l'​antislash le signification de ces caractères ​sont les mêmes que lors de leur utilisation avec l'​option -r.
  
 ===Exemples === ===Exemples ===
Ligne 1073: Ligne 1139:
   * Substituer "​Hello"​ par "​OK"​ :   * Substituer "​Hello"​ par "​OK"​ :
  
-<code user>​echo "​coucou Hello Yep" | sed '​s/​[A-Z]\{1\}[a-z]\{4\}/​OK/​g'</​code>​+<code user>​echo "​coucou Hello Yep" | sed -r '​s/​[A-Z]{1}[a-z]{4}/​OK/​g'</​code>​
 <​code>​ <​code>​
 coucou OK Yep coucou OK Yep
Ligne 1080: Ligne 1146:
   * Substituer "​a"​ et "​aa"​ par "​OK"​ :   * Substituer "​a"​ et "​aa"​ par "​OK"​ :
  
-<code user>​echo "a aa aaa aaaa aaaaaa aaaaaaaa"​ | sed -'s/\(a\{1\\)/​OK/'​\ +<code user>​echo "a aa aaa aaaa aaaaaa aaaaaaaa"​ | sed -re '​s/​(a{1} )/​OK/'​\ 
- -e 's/\(a\{2\\)/​OK/'</​code>​+ -e '​s/​(a{2} )/​OK/'</​code>​
 <​code>​ <​code>​
 OKOKaaa aaaa aaaaaa aaaaaaaa OKOKaaa aaaa aaaaaa aaaaaaaa
Ligne 1087: Ligne 1153:
  
 <note tip> <note tip>
-La lisibilité devient vite difficile pour sélectionner des sous-chaîne avec les ERb.\\  +L'​antislash de la commande précédente permet de couper ​les longues commandes.\\  
-Mieux vaut donc passer aux ERe, quand les commandes peuvent ​les utiliser.\\  +Ne pas confondre avec l'​antislash utiliser pour les ERb et les caractères spécifiquesparenthèses,​ accolades, etc.
-C'est justement le cas de la commande sedlocate et find. Je ne m'y attarderai donc pas.+
 </​note>​ </​note>​
  
-====find et les caractères spécifiques aux ERb " ====+====find et les caractères spécifiques aux ERe " ====
 __**Rappel **__\\ ​ __**Rappel **__\\ ​
  
-Pour utiliser les ERb, il faut utiliser l'​option ​ **''​-regextype "​posix-basic"​ ''​**.+Pour utiliser ​les ERe, il faut utiliser l'​option **''​-regextype "​posix-extended"​ ''​**.\\  
 + 
 +Pour les caractères **''​ <​nowiki>​[</​nowiki> ​ <​nowiki>​]</​nowiki> ​ <​nowiki>​{</​nowiki> ​ <​nowiki>​}</​nowiki> ​ ?  + ''​**,​ on peut là aussi choisir ​les ERb en mettant un antislash devant.\\  
 +Pour ce faire, il faut alors utiliser l'​option ​ **''​-regextype "​posix-basic"​ ''​**.
  
 __**Préparation**__\\ ​ __**Préparation**__\\ ​
Ligne 1118: Ligne 1186:
 </​code>​ </​code>​
  
-  ​caractère ​\? :+ou  
 + 
 +<code user>​find -regextype "​posix-extended"​ -regex "​.*[a-z]{,​3}-.*\.jpg$"</​code>​ 
 +<​code>​ 
 +./​img-perso-2.jpg 
 +./​img-perso-1.jpg 
 +</​code>​ 
 + 
 +  * caractère ​? :
 <code user>​find -regextype "​posix-basic"​ -regex "​.*/​liste.\?"</​code>​ <code user>​find -regextype "​posix-basic"​ -regex "​.*/​liste.\?"</​code>​
 <​code>​ <​code>​
Ligne 1126: Ligne 1202:
 </​code>​ </​code>​
  
-  * le caractère ​\+ (depuis le répertoire parent "​ERetCMD/"​ des fichiers) :  +  * le caractère + (depuis le répertoire parent "​ERetCMD/"​ des fichiers) :  
-<code user>​find -regextype "​posix-basic" -regex ".*/liste.\+"</​code>​+<code user>​find -regextype "​posix-extended" -regex "​.*liste.+"</​code>​
 <​code>​ <​code>​
 ./​liste2-nom ./​liste2-nom
Ligne 1139: Ligne 1215:
 </​code>​ </​code>​
  
-====locate et les caractères spécifiques aux ERb ====+====locate et les caractères spécifiques aux ERe ====
 __**Rappel**__\\ ​ __**Rappel**__\\ ​
  
-Pour utiliser les ERb, il faut utiliser l'​option **''​--regexp''​**.\\+Pour utiliser les ERe, il faut utiliser l'​option **''​--regex''​**.\\ ​ 
 +De même que précédemment,​ on peut choisir l'​option **''​--regexp''​** pour utiliser les caractères spécifiques aux ERb qui nécessitent **''​\''​**.
  
 Soit encore le répertoire "​ERetCMD/"​ contenant les mêmes fichiers (voir find).\\ ​ Soit encore le répertoire "​ERetCMD/"​ contenant les mêmes fichiers (voir find).\\ ​
Ligne 1162: Ligne 1239:
 </​code>​ </​code>​
  
-  ​caractère ​\? : +ou 
-<code user>​locate --regexp ​'/​liste.\?'</​code>​+ 
 +<code user>​locate --regex '​([a-z]{1,​} ){2}.*\.jpg$'</​code>​ 
 +<​code>​ 
 +/​home/​Téléchargements/​Les utilitaires awk, nawk et gawk - Tutoriel_fichiers/​logo.jpg 
 +/​home/​hypathie/​ERetCMD/​image linux - 01.jpg 
 +/​home/​hypathie/​ERetCMD/​image linux - 02.jpg 
 +/​home/​hypathie/​ERetCMD/​image linux - 03.jpg 
 +</​code>​ 
 + 
 +  * caractère ​? : 
 +<code user>​locate --regex '/​liste.?'</​code>​
 <​code>​ <​code>​
 /​home/​hypathie/​Documents/​PYTHON/​python2/​chap06/​liste_et_branch.py /​home/​hypathie/​Documents/​PYTHON/​python2/​chap06/​liste_et_branch.py
Ligne 1181: Ligne 1268:
 >Le fichier "​liste"​ (sans extension) apparaît. >Le fichier "​liste"​ (sans extension) apparaît.
  
-  * caractère ​\+ :+  * caractère + :
  
-<code user>​locate --regexp ​'/​liste.\+'</​code>​+<code user>​locate --regex '/​liste.+'</​code>​
 <​code>​ <​code>​
 /​home/​hypathie/​Documents/​PYTHON/​python2/​chap06/​liste_et_branch.py /​home/​hypathie/​Documents/​PYTHON/​python2/​chap06/​liste_et_branch.py
Ligne 1477: Ligne 1564:
  
  
-======Les expressions rationnelles étendues====== +======Raccourcis et commandes======
-====Caractères des ERe ====+
  
-^expressions ​               ^ Modèles reconnus ​            ^ 
-|**''?''​** | zéro ou une fois le caractère ou le regroupement précédent | 
-|**''​+''​** |une à n fois le caractère ou regroupement précédent | 
-|**''<​nowiki>​{m}</​nowiki>''​** |m fois le caractère précédent | 
-|**''<​nowiki>​{m,​}</​nowiki>''​** | m fois le caractère précédent | 
-|**''<​nowiki>​{m,​n}</​nowiki>''​** | entre m et n fois le caractère précédent | 
-|**''<​nowiki>​( er1)</​nowiki>''​** | regroupement | 
-|**''<​nowiki>​er1|er2|er3</​nowiki>''​** | alternative | 
-|**''<​nowiki>​(er)+</​nowiki>''​**|Une ou plus de une chaîne(s) consécutive(s) validée(s) "​er"​.| 
-|**''<​nowiki>​(er)*</​nowiki>''​**|zéro ou plus de zéro chaîne(s) consécutive(s) validée(s) par "​er"​ | 
-|**''<​nowiki>​(er)?</​nowiki>''​**|une chaîne bulle ou toute chaîne validée par "​er"​.| 
-|**''<​nowiki>​[c1c2...]</​nowiki>''​**|Tout caractère expressément listé entre les crochets.| 
-|**''<​nowiki>​[^c1c2...]</​nowiki>''​**|Tout caractère excepté ceux qui sont expressément listés entre les crochets.| 
-|**''<​nowiki>​[c1-c2]</​nowiki>''​**|Tout caractère appartenant à l’intervalle c1 c2, bornes comprises.| 
-|**''<​nowiki>​er1|er2</​nowiki>''​**|Toute chaîne de caractères validée soit par er1 soit par er2.| 
-|**''<​nowiki>​(er)(er)</​nowiki>''​**|Toute chaîne validée par l’expression er, chaîne vide exclue.| 
-|**''<​nowiki>​(er1)(er2)</​nowiki>''​**|Toute chaîne de caractères de type AB, dans laquelle l’expression régulière er1 valide A et l’expression régulière er2 valide B.\\ Avec awk uniquement| 
  
-Excepté **''<​nowiki>​(er1)(er2)</​nowiki>''​** :+Les raccourcis ne sont pas posix
  
-=== avec awk (sans option)=== +=== __sed__ ​:===
- +
-===avec grep -E et egrep=== +
-<code user>​grep -E "​1([A-Z]){2}.*"​ liste4-spec</​code>​ +
-<​code>​ +
-7 1AAA.AAA.bcdef aBcd6a 123* +
-</​code>​ +
- +
-===avec sed -r=== +
- +
-===avec locate === +
-<code man locate>​ +
---regex +
-              Interpret all PATTERNs as extended regexps. +
-</​code>​ +
- +
-  * Syntaxe ​: +
-<​code>​ +
-locate --regex '​ERe'​ +
-</​code>​ +
- +
-===avec find === +
-<code man find> +
--regextype type +
-              Définir la syntaxe des expressions rationnelles des tests -regex +
-              et -iregex qui seront indiqués plus loin sur la  ligne  de  com‐ +
-              mande. ​ Les  types actuellement implémentés sont emacs (type par +
-              défaut), posix-awk, posix-basic,​ posix-egrep et posix-extended. +
-</​code>​ +
- +
-  * Syntaxe : +
-<​code>​ +
-find -regextype "​posix-extended"​ -regex "​ERe"​ +
-</​code>​ +
- +
-====Les raccourcis ne sont pas posix==== +
- +
-  * __sed__ :+
  
 ^Séquences ​                  ​^Séquences ​                               ^ ^Séquences ​                  ​^Séquences ​                               ^
Ligne 1548: Ligne 1580:
 |**''<​nowiki>​\b</​nowiki>''​** | Correspond à une chaîne vide (blanc) à l'​extrémité d'un mot | |**''<​nowiki>​\b</​nowiki>''​** | Correspond à une chaîne vide (blanc) à l'​extrémité d'un mot |
  
- +=== __awk__ :===
- +
- +
-  * __awk__ :+
  
 ^Séquences ​                        ​^Séquences ​                                         ^ ^Séquences ​                        ​^Séquences ​                                         ^
Ligne 1560: Ligne 1589:
 |**''<​nowiki>​\c </​nowiki>''​** ​     | tout caractère pris sous sa forme littérale\\ excepté **''<​nowiki>​\</​nowiki>''​** ​ | |**''<​nowiki>​\c </​nowiki>''​** ​     | tout caractère pris sous sa forme littérale\\ excepté **''<​nowiki>​\</​nowiki>''​** ​ |
  
-__Excepté **''<​nowiki>​(er1)(er2)</​nowiki>''​**__ : 
- 
-  * Tous sont utilisables avec grep -E et egrep 
-  * Tous sont utilisable avec awk 
-  * Certains posent problème avec sed -r 
- 
-__Options nécessaires avec find et locate__ : 
- 
-  * find -regextype "​posix-extended"​\\ Les  types actuellement implémentés sont emacs (type par défaut), posix-awk, posix-basic,​ posix-egrep et posix-extended. 
- 
-  *locate --regex ​ :  Interpréter tous les "​PATTERNs"​ (modèles) comme des expressions rationnelles étendues. 
  
  
utilisateurs/hypathie/tutos/erb-et-ere-par-le-contexte-des-commandes.txt · Dernière modification: 01/10/2023 11:39 (modification externe)

Pied de page des forums

Propulsé par FluxBB