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 17:59]
Hypathie [Les commandes expr et vi et les caractères spécifiques aux ERb]
utilisateurs:hypathie:tutos:erb-et-ere-par-le-contexte-des-commandes [13/08/2014 18:32]
Hypathie [Les commandes expr et vi et les caractères spécifiques aux ERb]
Ligne 681: Ligne 681:
  
  
 +====L'​éditeur de texte vi n'​utilise que les ERb ====
  
 +===Préparation ===
 +<code user>cat liste4-vim</​code>​
 +<​code>​
 +Kc5 T5 c E2* abcd 7 9Abcd
 +7 1AAA.AAA.bcdef aBcd6a 123*
 +abc2356.99
 +73000|Savoie
 +index-tel|04|Rhône-Alpe
 +-15 +36 5687 {15} exemple{36}
 +il y a un truc et un truc et encore un truc et une chose
 +chose et truc ne font pas bon ménage
 +123.3456.abc
 +trucchosetruc
 +tructructruc
 +chosechosechose
 +</​code>​
  
 +<note tip>
 +Modes utilisés dans ce qui suit :\\ 
  
  
 +  * **Le mode normal**: celui dans lequel vous êtes à l'​ouverture du fichier. Il permet de taper des commandes.
 +    * Par exemple, la commande **:q!** pour sortir sans enregistrer ;
 +    * la commande **:wq** pour enregistrer et sortir
 +
 +  * **Le mode insertion**:​ Ce mode permet d'​insérer les caractères que vous saisissez à l'​intérieur du document. Pour passer en mode insertion, il suffit d'​appuyer sur **la touche "​i"​** ; touche "​Échap"​ pour en sortir.
 +
 +  * Pour tester ce qui suit si vous ne connaissez pas vi ou vim :\\ 
 +    *Après [[doc:​editeurs:​vim:​vim#​installation|installation de vim]], créer un fichier, par exemple "​liste4-vim"​ : ''​ vim liste4-vim ''​
 +    * Copier le contenu de "​liste4-vim"​ ci-dessus ;
 +    * Pour coller dans le fichier "​liste4-vim"​ édité avec vim : 
 +    * touche <​majuscule de droite> + touche <​inser>​ (cela fait que l'on est en mode insertion)
 +    * sortir du mode insertion : touche "​Échap"​
 +    * enregistrer et sortir : ''​ :wq ''​ et touche <​entrée>​
 +  * Pour apprendre les rudiments de l'​utilisation de vim (et donc de vi), après l'​installation de vim :
 +
 +  vimtutor
 +
 +-> Pour y ajouter l'​utilisation des //ER//, suivre ce qui suit.
 +</​note>​
 +
 +  * Éditer le fichier "​liste4-vim"​ :
 +  * Pour éditer le fichier avec vi ou vim :
 +
 +<code user>vi liste4-vim</​code>​
 +ou 
 +<code user>vim liste4-vim</​code>​
 +
 +{{http://​pix.toile-libre.org/​upload/​original/​1407922486.png?​400}}
 +
 +===Syntaxe d'​utilisation des ER===
 +
 +  * **recherche** en __mode interactif tapez (/)__ :
 +
 +  /​expression-rationnelle-basique
 +
 +<note tip>
 +  * /chaîne ou ER - rechercher ce qui correspond à chaîne ou les chaînes correspondant à ER
 +
 +  * n - rechercher l'​occurrence suivant de la chaîne
 +
 +  * N - rechercher l'​occurrence précédente de chaîne
 +</​note>​
 +
 +  * **substitution d'une occurrence** (depuis le mode interactif passer en __mode commande (:)__ :
 +
 +  :​[adresse[,​adresse]]s/​expression-rationnelle-basique/​remplacement/​[drapeau]
 +
 +  * **substitution sur tout le texte**, ou une portion __en mode commande (:)__ :
 +
 +  :​adresse%s/​chaine_a_remplacer/​chaine_de_remplacement/​
 +
 +<note tip>
 +  *g - drapeau - remplacer toutes les occurrences de le //ER// (si cette option n'est pas utilisée, vi substituera que la prochaine occurrence du motif)
 +
 +  *c - drapeau - confirmer le remplacement
 +
 +  *i - drapeau - ignorer la casse (prend en compte toutes les occurrences de la chaîne en majuscules ou en minuscules)
 +</​note>​
 +
 +===Exemples de recherches ===
 +  * le caractère début de ligne ^
 +<​code>​
 +/^chose
 +</​code>​
 +On appuie sur la touche shift+: pour inscrire ''/'',​ on inscrit sa ER, on valide avec la touche "​entrée"​. vi ou vim surligne toutes les occurrences de "​chose"​ qui sont en début de ligne.
 +
 +<​code>​nohlsearch</​code>​
 +Pour retirer la surbrillance de la recherche.
 +
 +  * le caractère fin de ligne $
 +<​code>​
 +/chose$
 +</​code>​
 +On valide avec entrée, et ''​nohlsearch''​ pour effacer
 +
 +
 +
 +===Exemples de substitution===
 +
 +  * crochets :
 +<​code>​
 +:​s/​[Ss]/​XXX/​g
 +</​code>​
 +>​Substitue les caractères "​S"​ ou "​s"​ à la ligne du curseur et surligne toutes les occurrences potentiellement substituables.
 +> **''​nohlsearch''​** pour retirer la surbrillance.
 +>puis pour annuler la substitution "​Échap",​ puis appuyer sur la lettre "​u"​ ("​u"​ pour annuler un seul changement, "​U"​ pour annuler plusieurs changement sur une ligne.
 +
 +  * idem sur tout le texte :
 +<​code>​
 +:​1,​$s/​[Ss]/​XXX/​g
 +</​code>​
 +
 +>"​1,​$"​ est l'​adressage qui signifie de la première ligne à la fin.
 +
 +  * sous-chaîne avec parenthèses et accolades :
 +<​code>​
 +/​\([0-9]\{3\}.\)\{2\}
 +</​code>​
 +Vi ou vim surligne à la ligne 9 (comportant "​123.3456.abc"​) la sous-chaîne **''​123.3456.''​**.
 +
 +  * utilisation de \| :
 +<​code>/​c\|t</​code>​
 +
 +->Une image vaut mieux qu'une description :\\
 +{{http://​pix.toile-libre.org/​upload/​original/​1407937898.png?​400}}
 +
 +
 +====La commande expr n'​utilise que ERb====
 +===Préparation ===
 +Soit le fichier "<​nowiki>​liste4-spec</​nowiki>"​ :
 +<code user>cat liste4-spec</​code>​
 +<​code>​
 +gdd:​a:​aa:​aaa:​aaaa:​aaaaaa:​aaaaaaaa
 +T5c Kc5 T5 c E2* abcd 7 9Abcd
 +7 1AAA.AAA.bcdef aBcd6a 123*
 +abc2356.99
 +73000|Savoie
 +123456
 +1234567
 +index-tel|04|Rhône-Alpe
 +-15 +36 5687 {15} exemple{36}
 +il y a un truc et un truc et encore un truc et une chose
 +choses et trucs ne font pas bon ménage
 +123.3456.abc
 +trucschosetruc
 +tructructrucs
 +chosechosechose
 +</​code>​
 +===Syntaxe ===
 +
 +  expr chaîne-de-caractères : expression-rationnelle-basique
 +
 +<note tip>
 +  * La commande expr utilise l'​opérateur **'':''​** pour mettre en correspondance une chaîne de caractères avec une //ER//.
 +  * Si le nombre de caractères de la chaîne correspond à l'ERb, alors expr affiche ce nombre à l'​écran.
 +  * Si la correspondance décrite ci-dessus est vraie, le code de retour est 0 (zéro).
 +  * Si elle est fausse, expr retourne 0 (zéro) pour "zéro correspondance) et le code de retour est 1 (un).
 +  * L'​expression rationnelle est comparée par rapport au début de la variable, le caractère **''​^''​** est toujours implicite.
 +  * Si une partie de l'​expression rationnelle est mémorisée avec **''​\( \)''​** la commande expr affiche dans le terminal la partie correspondante.
 +
 +
 +</​note>​
 +
 +===Exemples ===
 +  * crochet, étoile, fin de ligne :
 +<code user>​var=123</​code>​
 +<code user>​expr "​$var"​ : '​[0-9]*$'</​code>​
 +<​code>​
 +3
 +</​code>​
 +
 +>"​3"​ ne doit pas être confondu avec un code de retour, c'est le nombre de caractères de la variable qui correspondent à //ER//.
 +
 +<code user>​echo $?</​code>​
 +<​code>​
 +0
 +</​code>​
 +
 +>La correspondance est vraie : code de retour "​0"​.
 +>La variable comporte bien 3 caractères 1, 2, et 3 et non le chiffre "​123";​ il s'agit d'une comparaison sur chaîne de caractères.
 +
 +  * ER qui ne correspond pas à la chaîne de la variable :
 +<code user>​var="​les bonbons, c'est bon"</​code>​
 +<code user>​expr "​$var"​ : '​bons\>'</​code>​
 +<​code>​
 +0
 +</​code>​
 +
 +>zéro est le nombre de caractère correspondant
 +
 +<code user>​echo $?</​code>​
 +<​code>​
 +1
 +</​code>​
 +
 +> Le chiffre "​1"​ est le code de retour.
 +
 +  * sous chaîne avec caractère fin de mot :
 +<code user>​var="​les bonbons, c'est bon"</​code>​
 +<code user>​expr "​$var"​ : '​\(.*bons\>​\),'</​code>​
 +<​code>​
 +les bonbons
 +</​code>​
 +
 +>​Demander le code de retour est inutile, la ER est forcément juste, s'il y a affichage de la sous-chaîne correspondante. À moins d'en avoir besoin lors d'une utilisation de expr dans un script shell s'en servant pour un test.
  
  
Ligne 753: Ligne 957:
  
 ====La commande expr n'​utilise que ERb==== ====La commande expr n'​utilise que ERb====
-===Préparation === +__ 
-Soit le fichier "<​nowiki>​liste4-spec</​nowiki>"​ :+**Rappel :**__\\  
 + 
 +  * Soit le fichier "<​nowiki>​liste4-spec</​nowiki>"​ : 
 <code user>cat liste4-spec</​code>​ <code user>cat liste4-spec</​code>​
 <​code>​ <​code>​
Ligne 773: Ligne 980:
 chosechosechose chosechosechose
 </​code>​ </​code>​
-===Syntaxe ​===+ 
 +  * Syntaxe ​:
  
   expr chaîne-de-caractères : expression-rationnelle-basique   expr chaîne-de-caractères : expression-rationnelle-basique
  
 <note tip> <note tip>
-  * La commande expr utilise l'​opérateur **'':''​** pour mettre en correspondance une chaîne de caractères avec une //ER//. +
-  * Si le nombre de caractères de la chaîne correspond à l'ERb, alors expr affiche ce nombre à l'​écran. +
-  * Si la correspondance décrite ci-dessus est vraie, le code de retour est 0 (zéro). +
-  * Si elle est fausse, expr retourne 0 (zéro) pour "zéro correspondance) et le code de retour est 1 (un). +
-  * L'​expression rationnelle est comparée par rapport au début de la variable, le caractère **''​^''​** est toujours implicite. +
-  * Si une partie de l'​expression rationnelle est mémorisée avec **''​\( \)''​** la commande expr affiche dans le terminal la partie correspondante.+
   * **''​expr''​** utilise tous les [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-communs-aux-erb-et-ere|caractères communs aux ERb et ERe]]   * **''​expr''​** utilise tous les [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-communs-aux-erb-et-ere|caractères communs aux ERb et ERe]]
   * mais elle n'​utilise que les caractères spécifiques aux ERb ci-dessous :   * mais elle n'​utilise que les caractères spécifiques aux ERb ci-dessous :
Ligne 795: Ligne 998:
 </​note>​ </​note>​
  
-===Exemples ​=== +===Exemple ​===
-  * crochet, étoile, fin de ligne : +
-<code user>​var=123</​code>​ +
-<code user>​expr "​$var"​ : '​[0-9]*$'</​code>​ +
-<​code>​ +
-+
-</​code>​ +
- +
->"​3"​ ne doit pas être confondu avec un code de retour, c'est le nombre de caractères de la variable qui correspondent à //ER//. +
- +
-<code user>​echo $?</​code>​ +
-<​code>​ +
-+
-</​code>​ +
- +
->La correspondance est vraie : code de retour "​0"​. +
->La variable comporte bien 3 caractères 1, 2, et 3 et non le chiffre "​123";​ il s'agit d'une comparaison sur chaîne de caractères. +
- +
-  * ER qui ne correspond pas à la chaîne de la variable : +
-<code user>​var="​les bonbons, c'est bon"</​code>​ +
-<code user>​expr "​$var"​ : '​bons\>'</​code>​ +
-<​code>​ +
-+
-</​code>​ +
- +
->zéro est le nombre de caractère correspondant +
- +
-<code user>​echo $?</​code>​ +
-<​code>​ +
-+
-</​code>​ +
- +
-> Le chiffre "​1"​ est le code de retour. +
- +
-  * sous chaîne avec caractère fin de mot : +
-<code user>​var="​les bonbons, c'est bon"</​code>​ +
-<code user>​expr "​$var"​ : '​\(.*bons\>​\),'</​code>​ +
-<​code>​ +
-les bonbons +
-</​code>​ +
- +
->​Demander le code de retour est inutile, la ER est forcément juste, s'il y a affichage de la sous-chaîne correspondante. À moins d'en avoir besoin lors d'une utilisation de expr dans un script shell s'en servant pour un test.+
  
   * sous-chaîne et quantificateur accolades :   * sous-chaîne et quantificateur accolades :
Ligne 858: Ligne 1020:
  
 ====L'​éditeur de texte vi et les caractères spécifiques aux ERb==== ====L'​éditeur de texte vi et les caractères spécifiques aux ERb====
 +
 +<note tip>
 + ​**''​ vi''​** (vim) utilise 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]], tous [[utilisateurs:​hypathie:​tutos:​erb-et-ere-par-le-contexte-des-commandes?&#​caracteres-specifiques-aux-erb|les caractères spécifiques aux ERb]], y compris ceux ci-dessous (comme "les commandes à option"​ permettant de choisir le type //ER//):
 +
 +|**''<​nowiki>​\?</​nowiki>''​** | zéro ou une fois l'​élément précédent |
 +|**''<​nowiki>​\+</​nowiki>''​** | une ou plusieurs fois l'​élément précédent |
 +|**''<​nowiki>​\|</​nowiki>''​** | alternative |
 +
 +</​note>​
  
   * Reprise du fichier "​liste4-vim"​ :   * Reprise du fichier "​liste4-vim"​ :
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