IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PL/SQL Oracle Discussion :

Formatage avec expressions régulières


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2010
    Messages : 31
    Par défaut Formatage avec expressions régulières
    Bonjour à tous !

    Y'a-t-il un moyen de formater une chaîne de caractères en appliquant un "masque" ?

    exemple :

    masque : 'XX X XX XXXXX'

    chaîne à formater : '99999789'

    Résultat attendu : '00 9 99 99789'

    Je peux bien sûr le faire de manière traditionnelle, mais je pense qu'une utilisation des expresssions régulières est possible. Qu'en pensez-vous ? Peut-on me mettre sur la voie ?

    Un grand merci à tous.

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par wahnfried Voir le message
    ...Je peux bien sûr le faire de manière traditionnelle...
    C'est la meilleure solution.
    "Using Back References to Reposition Characters"

  3. #3
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Les expressions régulières étant assez coûteuses en ressources, le mieux reste d'utiliser ce bon vieux to_char :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    With Numbers as
    (
     select trunc(dbms_random.value(power(10, level-1), power(10, level))) as col
       from dual
    connect by level <= 10
    )
    select col
         , regexp_replace(to_char(col, 'fm0000000000'),
                          '([[:digit:]]{2})([[:digit:]]{1})([[:digit:]]{2})([[:digit:]]{5})',
                          '\1 \2 \3 \4')                                    as col_r
         , to_char(col, 'fm00G0G00G00000', 'nls_numeric_characters='', ''') as col_c
      from Numbers;
     
           COL COL_R          COL_C         
    ---------- -------------- --------------
             2 00 0 00 00002  00 0 00 00002 
            62 00 0 00 00062  00 0 00 00062 
           319 00 0 00 00319  00 0 00 00319 
          5804 00 0 00 05804  00 0 00 05804 
         87722 00 0 00 87722  00 0 00 87722 
        383382 00 0 03 83382  00 0 03 83382 
       2752830 00 0 27 52830  00 0 27 52830 
      67419795 00 6 74 19795  00 6 74 19795 
     692348101 06 9 23 48101  06 9 23 48101 
    4802078112 48 0 20 78112  48 0 20 78112

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : Royaume-Uni

    Informations forums :
    Inscription : Novembre 2008
    Messages : 46
    Par défaut
    Merci pour le lien mnitu.

    Par ailleurs je lis cette meme reflexion dans la plupart des threads qui parlent d'expressions regulieres
    Les expressions régulières étant assez coûteuses en ressources, le mieux reste d'utiliser ce bon vieux to_char
    Alors quand doit-on utiliser les expressions regulieres ??

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Quand on n'a pas le choix me paraît être un bon candidat !
    Ici le besoin était finalement assez simple pour être résolu avec to_char, mais ce n'est pas toujours le cas bien entendu.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2010
    Messages : 31
    Par défaut Merci à tous
    J'ai retenu la version TO_CHAR qui fonctionne parfaitement.

    Je m'endormirai ce soir un peu moins bête grâce à vous.


+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [PEAR][HTML_QuickForm] Création de filtre avec expression régulière
    Par audran12 dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 26/06/2007, 11h31
  2. pb avec expression régulière (regex)
    Par rudhf dans le forum C#
    Réponses: 12
    Dernier message: 10/05/2007, 15h20
  3. [RegEx] Contrôle avec expression régulière
    Par lodan dans le forum Langage
    Réponses: 8
    Dernier message: 23/10/2006, 19h32
  4. [RegEx] Problème avec expressions régulières.
    Par Cygnus Saint dans le forum Langage
    Réponses: 12
    Dernier message: 14/08/2006, 11h55
  5. [C#] Caractères hexadécimal avec expressions régulières
    Par shinchan dans le forum Windows Forms
    Réponses: 4
    Dernier message: 16/01/2006, 11h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo