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 :

Problème d'arrondi avec awk


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Enseignant Chercheur
    Inscrit en
    Avril 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2016
    Messages : 11
    Par défaut Problème d'arrondi avec awk
    Bonjour,

    awk arrondit les valeurs du fichier que je lui donne en lecture, ce que je ne veux pas.
    Avec le code suivant, si j'ai les valeurs 46.90 et 11.40 dans la 4ème et la 5ème colonne de mon fichier d'entrée respectivement, le résultat de la dernière ligne de ce code me donne : 46.0000 et 11.0000 dans mon nouveau fichier.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    BEGIN {
    }
    {
            nobs=0;
            intensite=0;
            if(match($4,"999")==0){intensite=1;nobs=nobs+1;};
            if(intensite==1){printf("%10.4f%10.4f   5",$4,$5)};
    }
    Je ne comprends pas d'où vient l'arrondi ?

    Merci d'avance

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 664
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 664
    Par défaut
    Bonjour,

    je n'observe pas ça avec [gmn]awk :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $ awk '{printf("%10.4f%10.4f", $1,$2}' <<< "46.90, 11.40"
       46.9000   11.4000$
    mais avec original-awk, oui.

    fais précéder ta commande awk de la variable d'environnement LC_NUMERIC=C
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $ original-awk '{printf("%10.4f%10.4f\n", $1+0, $2+0)}' <<<"46.90 11,40" #note le changement de séparateur décimal.
       46,0000   11,4000
    $ LC_NUMERIC=C original-awk '{printf("%10.4f%10.4f\n", $1+0, $2+0)}' <<<"46.90 11,40"
       46.9000   11.0000
    $
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre averti
    Femme Profil pro
    Enseignant Chercheur
    Inscrit en
    Avril 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2016
    Messages : 11
    Par défaut
    Super, ça marche !
    Merci beaucoup !

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

Discussions similaires

  1. [AC-2003] Problème d'arrondi avec les champs de type réel simple
    Par gege2061 dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 15/09/2009, 17h58
  2. problème d'arrondi avec gawk
    Par tonio_a_588 dans le forum Shell et commandes GNU
    Réponses: 1
    Dernier message: 09/04/2009, 10h26
  3. Réponses: 3
    Dernier message: 15/09/2008, 14h24
  4. Problème de variable avec awk
    Par carlou135 dans le forum Linux
    Réponses: 5
    Dernier message: 24/11/2007, 09h30
  5. Problème avec awk
    Par Michaël dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 16/08/2006, 13h30

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