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

POWER Discussion :

[Power Query] Cumuler des colonnes


Sujet :

POWER

  1. #1
    Community Manager

    Avatar de Malick
    Homme Profil pro
    Community Manager
    Inscrit en
    Juillet 2012
    Messages
    9 131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Community Manager
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2012
    Messages : 9 131
    Points : 83 964
    Points
    83 964
    Billets dans le blog
    15
    Par défaut [Power Query] Cumuler des colonnes
    Bonjour,

    Serait-il possible de simplifier cette fonction pour faire la somme des données présentes dans les colonnes (Jour 1, Jour 2, .... Jour 31) ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Table.AddColumn(#"Colonnes renommées1", "Cumul_Temps", each List.Sum({[Jour 1],[Jour 2],[Jour 3],[Jour 4],[Jour 5],[Jour 6],[Jour 7],[Jour 8],[Jour 9],[Jour 10],[Jour 11],[Jour 12],[Jour 13],[Jour 14],[Jour 15],[Jour 16],[Jour 17],[Jour 18],[Jour 19],[Jour 20],[Jour 21],[Jour 22],[Jour 23],[Jour 24],[Jour 25],[Jour 26],[Jour 27],[Jour 28],[Jour 29],[Jour 30],[Jour 31]}))
    Merci d'avance
    Vous avez envie de contribuer au sein du Club Developpez.com ? Contactez-nous maintenant !
    Vous êtes passionné, vous souhaitez partager vos connaissances en informatique, vous souhaitez faire partie de la rédaction.
    Il suffit de vous porter volontaire et de nous faire part de vos envies de contributions :
    Rédaction d'articles/cours/tutoriels, Traduction, Contribution dans la FAQ, Rédaction de news, interviews et témoignages, Organisation de défis, de débats et de sondages, Relecture technique, Modération, Correction orthographique, etc.
    Vous avez d'autres propositions de contributions à nous faire ? Vous souhaitez en savoir davantage ? N'hésitez pas à nous approcher.

  2. #2
    Membre émérite
    Homme Profil pro
    ingénieur
    Inscrit en
    Mars 2015
    Messages
    1 054
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : ingénieur
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2015
    Messages : 1 054
    Points : 2 515
    Points
    2 515
    Par défaut
    Bonjour

    il y a peut être plus simple mais ça doit fonctionner :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    each List.Sum(Record.ToList(Record.SelectFields(_,List.Transform({1..31},each "Jour "&Text.From(_)))))
    List.Transform pour définir les 31 champs
    Record.SelectFields pour récupérer ces 31 champs de l'enregistrement en cours
    Record.ToList pour convertir l'enregistrement en liste
    et le List.Sum pour additionner le tout

    Après le mieux est peut être de décroiser la table.

    Stéphane

  3. #3
    Community Manager

    Avatar de Malick
    Homme Profil pro
    Community Manager
    Inscrit en
    Juillet 2012
    Messages
    9 131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Community Manager
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2012
    Messages : 9 131
    Points : 83 964
    Points
    83 964
    Billets dans le blog
    15
    Par défaut
    Bonjour,

    Merci Stéphane ==> Je regarde cela et vous reviens.

    Vous avez envie de contribuer au sein du Club Developpez.com ? Contactez-nous maintenant !
    Vous êtes passionné, vous souhaitez partager vos connaissances en informatique, vous souhaitez faire partie de la rédaction.
    Il suffit de vous porter volontaire et de nous faire part de vos envies de contributions :
    Rédaction d'articles/cours/tutoriels, Traduction, Contribution dans la FAQ, Rédaction de news, interviews et témoignages, Organisation de défis, de débats et de sondages, Relecture technique, Modération, Correction orthographique, etc.
    Vous avez d'autres propositions de contributions à nous faire ? Vous souhaitez en savoir davantage ? N'hésitez pas à nous approcher.

  4. #4
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 409
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 409
    Points : 16 250
    Points
    16 250
    Par défaut
    Bonjour

    En complément de l'excellente solution de Raccourcix

    on peut aussi se baser sur la position des colonnes

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Table.AddColumn(#"Colonnes renommées1", "Cumul_Temps", each List.Sum(List.Range(Record.ToList(_),1,Table.ColumnCount(#"Colonnes renommées1")-1)))
    1 représente ici la colonne à partir de laquelle on somme : la première étant 0, 1 est donc la 2ème, et le -1 doit compenser

    Par exemple de 5ème à la fin aura 4 et -4
    ou plus - x à calculer si on ne va pas jusqu'à la dernière colonne
    Chris
    PowerQuery existe depuis plus de 13 ans, est totalement intégré à Excel 2016 &+. Utilisez-le !

    Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson.
    Confucius

    ----------------------------------------------------------------------------------------------
    En cas de résolution, n'hésitez pas cliquer sur c'est toujours apprécié...

  5. #5
    Membre émérite
    Homme Profil pro
    ingénieur
    Inscrit en
    Mars 2015
    Messages
    1 054
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : ingénieur
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2015
    Messages : 1 054
    Points : 2 515
    Points
    2 515
    Par défaut
    Bonjour

    Autres possibilités si vous ne voulez pas conserver les colonnes source et avoir uniquement le total.
    par défaut en utilisant la "fusion des colonnes" c'est une fonction Combiner.CombineTextByDelimiter qui est générée mais on peut la remplacer par un List.Sum

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = Table.CombineColumns(#"Colonnes renommées1",List.Transform({1..31}, each "Jour "&Text.From(_)),List.Sum,"Cumul_Temps")
    A tester mais ça peut être plus efficace qu'un traitement par Record.

    Stéphane

  6. #6
    Community Manager

    Avatar de Malick
    Homme Profil pro
    Community Manager
    Inscrit en
    Juillet 2012
    Messages
    9 131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Community Manager
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2012
    Messages : 9 131
    Points : 83 964
    Points
    83 964
    Billets dans le blog
    15
    Par défaut
    Bonjour à vous,

    Je confirme que vos différentes propositions fonctionnent toutes

    Cela démontre encore la puissance de Power Query pour automatiser des tâches sans passer par du VBA.

    encore
    Vous avez envie de contribuer au sein du Club Developpez.com ? Contactez-nous maintenant !
    Vous êtes passionné, vous souhaitez partager vos connaissances en informatique, vous souhaitez faire partie de la rédaction.
    Il suffit de vous porter volontaire et de nous faire part de vos envies de contributions :
    Rédaction d'articles/cours/tutoriels, Traduction, Contribution dans la FAQ, Rédaction de news, interviews et témoignages, Organisation de défis, de débats et de sondages, Relecture technique, Modération, Correction orthographique, etc.
    Vous avez d'autres propositions de contributions à nous faire ? Vous souhaitez en savoir davantage ? N'hésitez pas à nous approcher.

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

Discussions similaires

  1. Power Query - Croiser des données Texte
    Par Philippe Tulliez dans le forum POWER
    Réponses: 16
    Dernier message: 14/06/2021, 14h15
  2. Réponses: 6
    Dernier message: 28/05/2019, 13h34
  3. [XL-2016] Power Query - Remplacer des null par une extrapolation linéaire
    Par junior76 dans le forum Excel
    Réponses: 0
    Dernier message: 15/03/2019, 15h49
  4. [2008R2] Query dans Query manque des colonnes
    Par tornade69 dans le forum Développement
    Réponses: 5
    Dernier message: 26/07/2013, 21h56
  5. Réponses: 6
    Dernier message: 30/12/2006, 15h18

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