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

Shell et commandes GNU Discussion :

Contrôle de format décimal


Sujet :

Shell et commandes GNU

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 32
    Par défaut Contrôle de format décimal
    Bonsoir,

    J'ai la troisième colonne de mon fichier qui doit être du type décimal, genre number(2,1). Je souhaite vérifier que les données de cette colonne sont conformes au format attendu. Voici mon code en awk :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if ($3 !~ /^[[:digit:]][.][[:digit:]]*$) print "Erreur|"$3
    Le souci est que cette colonne peut avoir les valeurs suivantes :
    Le code ci-dessous me retourne ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Erreur|1
    2.1
    1.4
    Erreur|2
    Certes le premier chiffre et le dernier ne contiennent pas de virgule mais il n'empêche qu'ils sont correctes puisqu'ils peuvent s'écrire "1.0" et "2.0". Comment dire à mon programme qu'il faut les prendre ?

  2. #2
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 376
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 376
    Par défaut
    Bonjour,

    Le code awk que tu donnes ne fonctionne pas.

    Sinon, la regex est la suivante en me calquant sur ce que tu donnes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    /^[[:digit:]][.]{0,1}[[:digit:]]*$/
    J'ai juste repris ta base et je check en plus s'il y a zéro ou un point.

  3. #3
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 103
    Par défaut
    Citation Envoyé par disedorgue Voir le message
    Le code awk que tu donnes ne fonctionne pas.
    il manque les accolades encadrantes.

    Sinon, la regex est la suivante en me calquant sur ce que tu donnes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    /^[[:digit:]][.]{0,1}[[:digit:]]*$/
    J'ai juste repris ta base et je check en plus s'il y a zéro ou un point.
    Mouais...

    [chipotage]
    Ta regexp matche aussi 12 123 1234 ainsi que 1. 1.23 1.234 etc.
    Je ne suis pas sûr que ce soit ce que veut Taxan.
    C'est amusant, mais, pour une fois, les spécifications ne sont pas très précises...

    Si les valeurs acceptées sont exactement:
    [[:digit:]]
    [[:digit:]][.]
    [[:digit:]][.][[:digit:]]
    alors je propose le code suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '{if ($3 !~ /^[[:digit:]][.]{0,1}$/ && $3 !~ /^[[:digit:]][.][[:digit:]]$/) print "Erreur|"$3}'
    [/chipotage]

  4. #4
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 376
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 376
    Par défaut
    Citation Envoyé par jack-ft Voir le message
    [chipotage]
    Ta regexp matche aussi 12 123 1234 ainsi que 1. 1.23 1.234 etc.
    Je ne suis pas sûr que ce soit ce que veut Taxan.
    C'est amusant, mais, pour une fois, les spécifications ne sont pas très précises...
    [/chipotage]
    [superchipotage]
    Le nombre doit être de type décimal (c'est se qu'il dit dans ses spécifications), donc pour savoir si celui-ci est bien de ce type, il nous faudrait la formule de développement qui génère ce nombre afin que l'on puisse déterminer si selon les valeurs d'entrées on a bien au final en sortie un nombre dont le développement est fini.
    Exemple simple avec la division:
    5/2 = 2,5 <= on a ici un developpement fini, ce qui par définition nous donne bien un nombre décimal
    5/3 = 1,6666... <= ici on a un developpement infini, donc ce nombre n'est pas un décimal
    Donc, selon cette définition, ma regex est bonne
    [/superchipotage]

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 32
    Par défaut
    Bonsoir,

    Avant tout, merci pour vos réponses.

    Pour être plus précis, je ne connais que la structure de mon fichier.
    Par exemple, la troisième colonne est un décimal(2,1). Une autre colonne peut être du type décimal (5,4). Mon objectif est de vérifier que la donnée que j'ai reçue dans mon fichier est bien de ce type là. A l'exception de la structure de mon fichier, je n'ai aucune information sur le mode de calcul desdites colonnes.

    D'ailleurs, je me demande si ce n'est pas plus judicieux de récupérer le chiffre avant la virgule et celui d'après la virgule, ensuite de s'assurer qu'ils sont bien du type [[:digit:]].

    Si je prends un exemple de décimal(6,5). Je peux recevoir ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    0,12345
    1,23456
    0,09
    Ce qui signifie que le 0.09 doit sortir en erreur puisqu'il n'y a pas 5 chiffres après la virgule comme le précise le format de la donnée.

  6. #6
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 376
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 376
    Par défaut
    C'est un peu contradictoire par rapport aux spécifications du départ:
    dans le cas d'un décimal(2.1) tu dis que 1 est valable car on peut aussi l'écrire 1.0
    donc il faudrait expliquer la différence que tu vois entre 0.09 et 0.09000 car mathématiquement, c'est le même nombre.

    Et une autre question: que représente le premier le 2 de décimal(2,1) ou le 6 de décimal(6,5) ?

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 32
    Par défaut
    décimal(2,1) signifie deux chiffres dont 1 après la virgule
    décimal(6,5) signifie six chiffres dont 5 après la virgule

    Tu as raison sur le premier exemple que j'ai cité. Le chiffre 1 doit sortir en erreur puisqu'il ne donne aucune précision sur sa virgule. Logiquement, je devrais recevoir 1.0 et non pas 1

    Je vais creuser le sujet et en attendant, je fais passer le statut à "Résolu" puisque le code fourni fonctionne.

    Merci pour votre réactivité.

  8. #8
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 376
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 376
    Par défaut
    Par rapport aux dernières infos que tu donnes, une syntaxe plus stricte et plus correcte serait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '{ if ($3 !~ /^[[:digit:]]{1,2}[.]{1,1}[[:digit:]]{5,5}$/) print "Erreur|"$3 ; else print}'
    ici, j'ai droit pour la troisième colonne a des nombres :
    1.23456
    12.34567
    donc obligatoirement:
    1 ou 2 chiffres avant le point
    1 point
    5 chiffres après le point

    Si tu veux faire varier par exemple:
    entre 2 et 6 chiffres après le point, il suffit de remplacer {5,5} par {2,6}

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

Discussions similaires

  1. Récupération de résultat sous le format décimal
    Par CREZ59 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 12/07/2006, 12h14
  2. Format décimal dans les fichiers XML
    Par wozzz dans le forum XML/XSL et SOAP
    Réponses: 3
    Dernier message: 31/05/2006, 09h18
  3. Format décimale
    Par priest69 dans le forum Access
    Réponses: 1
    Dernier message: 29/09/2005, 17h49
  4. [date] Contrôle de format et contrôle d'intervalle
    Par dodik dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/06/2005, 16h14
  5. [Fortran] Format décimal des nombres
    Par bert24 dans le forum Fortran
    Réponses: 4
    Dernier message: 12/05/2005, 17h55

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