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

Langage PHP Discussion :

additionner des valeurs


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut additionner des valeurs
    Bonjour
    je voudrais savoir comment calculer le total de la fonction suivante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    foreach ($vendor_orders as $order_id) {
                $order = wc_get_order($order_id);
                $vendor_order = wcmp_get_order($order_id);
                if ($order) {
    echo $vendor_order->get_commission_total();
    }}
    ce code me retourne tout les valeur des commandes qui sont 5, 4 et 3
    j'aimerai savoir svp comment faire pour additionner les chiffres retournée par la fonction
    je vous remercie d'avance pour vos reposes.

  2. #2
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 200
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 200
    Points : 8 425
    Points
    8 425
    Billets dans le blog
    17
    Par défaut
    Tu peux cumuler les valeurs retournées dans une variable :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
        $order = wc_get_order($order_id);
        $vendor_order = wcmp_get_order($order_id);
        if ($order) {
            $amount = $vendor_order->get_commission_total();
            echo $amount;
            $sum = $sum + $amount;
        }
    }
    echo "Montant total : {$sum}";

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    merci seb pour votre repense mai la somme est en euro
    malheureusement sa me renvois cette erreurs :
    Warning: A non-numeric value encountered in /var/////

  4. #4
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 200
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 200
    Points : 8 425
    Points
    8 425
    Billets dans le blog
    17
    Par défaut
    Donne un exemple de valeur.

  5. #5
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Le code proposé par Séb. au post#2 semble correct. Peux-tu dire ce que ça te retourne :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
        $order = wc_get_order($order_id);
        $vendor_order = wcmp_get_order($order_id);
        if ($order) {
            $amount = $vendor_order->get_commission_total();
            var_dump($amount); echo "<br/>";
        }
    }
    J'ai supprimé les lignes qui provoquent probablement le message d'erreur.

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    Citation Envoyé par Séb. Voir le message
    Donne un exemple de valeur.

    encore merci pour vos repense exemple des valeurs de la fonction $vendor_order->get_commission_total();,
    0,65
    5,09
    7,99

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Le code proposé par Séb. au post#2 semble correct. Peux-tu dire ce que ça te retourne :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
        $order = wc_get_order($order_id);
        $vendor_order = wcmp_get_order($order_id);
        if ($order) {
            $amount = $vendor_order->get_commission_total();
            var_dump($amount); echo "<br/>";
        }
    }
    J'ai supprimé les lignes qui provoquent probablement le message d'erreur.
    merci pour votre repense mai sa m'affiche les valeurs indiquer si dessus

  8. #8
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    OK,
    dans ce cas, donne le warning complet (avec le numéro de ligne), qu'on sache quelle ligne le gêne...

  9. #9
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    OK,
    dans ce cas, donne le warning complet (avec le numéro de ligne), qu'on sache quelle ligne le gêne...
    merci pour votre repense voila l'erreur
    Warning: A non-numeric value encountered in /var/////
    sur la ligne suivante :

  10. #10
    Expert éminent sénior
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 094
    Points : 16 606
    Points
    16 606
    Par défaut
    Salut

    SI les données récupérées sont exactement
    0,65
    5,09
    7,99

    Le séparateur décimal étant une virgule et non pas un point, tu tentes d'additionner un numérique $sum à un littéral $amount me semble t il.

  11. #11
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Bien vu ProgElecT,

    donc il conviendrait de faire :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
        $order = wc_get_order($order_id);
        $vendor_order = wcmp_get_order($order_id);
        if ($order) {
            $amount = $vendor_order->get_commission_total();
            echo $amount;
            $amount=(float)str_replace(',','.',$amount);
            $sum = $sum + $amount;
        }
    }
    echo "Montant total : {$sum}";

  12. #12
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    Citation Envoyé par ProgElecT Voir le message
    Salut

    SI les données récupérées sont exactement
    0,65
    5,09
    7,99

    Le séparateur décimal étant une virgule et non pas un point, tu tentes d'additionner un numérique $sum à un littéral $amount me semble t il.
    merci pour votre repense malheureusement je j'ai pas la main sur les autres parties du code pour que je puisse faire les modifications j'ai que cette partie
    avez vous une idée svp ?

  13. #13
    Nouveau membre du Club
    Homme Profil pro
    Technicien réseau
    Inscrit en
    Février 2022
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien réseau

    Informations forums :
    Inscription : Février 2022
    Messages : 58
    Points : 37
    Points
    37
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Bien vu ProgElecT,

    donc il conviendrait de faire :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
        $order = wc_get_order($order_id);
        $vendor_order = wcmp_get_order($order_id);
        if ($order) {
            $amount = $vendor_order->get_commission_total();
            echo $amount;
            $amount=(float)str_replace(',','.',$amount);
            $sum = $sum + $amount;
        }
    }
    echo "Montant total : {$sum}";
    encore merci pas d'erreur cette fois mai le résultat est toujours nul
    voila le résultat :
    0,65 €
    5,09 €
    7,99 €
    Montant total : 0

  14. #14
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    S'il y a aussi le symbole € :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $sum = 0; // Contient le cumul
    foreach ($vendor_orders as $order_id) {
    $order = wc_get_order($order_id);
    $vendor_order = wcmp_get_order($order_id);
    if ($order) {
       $amount = $vendor_order->get_commission_total();
       echo $amount;
       $amount=(float)str_replace([',', ' €'],['.',''],$amount);  //tenir compte de l'espace entre le chiffre et €
       $sum = $sum + $amount;
       }
    }
    echo "Montant total : {$sum}";

Discussions similaires

  1. Additionner des valeurs contenues dans des .txt
    Par herroP dans le forum VB.NET
    Réponses: 7
    Dernier message: 29/05/2012, 21h30
  2. Additionner des valeurs des plusieurs fichiers
    Par Gogia dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 23/09/2011, 15h33
  3. additionner des valeurs en hexa provenant d'un chaine
    Par matlinuxos dans le forum Débuter
    Réponses: 9
    Dernier message: 29/08/2011, 18h04
  4. additionner des valeurs entre 2 dates
    Par mgrizzly dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 21/04/2010, 16h38
  5. Réponses: 5
    Dernier message: 29/03/2007, 16h52

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