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 BI Discussion :

Répartition de jours ouvrés mensuellement


Sujet :

Power BI

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut Répartition de jours ouvrés mensuellement
    Bonjour à tous,

    Voici la situation :

    J'ai une base de données avec des dates de début et de fin, je voudrai connaitre le nombre de jours ouvrés entre ces 2 dates.
    Cette première partie, je l'ai retranscrite en excluant également les jours fériés.=> Ok

    Maintenant ce que je cherche à faire, c'est un graphique en histogramme groupé mensuellement ce qui ne pose pas de problème en soit.

    Par contre, la répartition du nombre de jour n'est pas correcte, car je peux avoir un intervalle de date du 14/11/2020 au 18/12/2020 par exemple et du coup, il me comptabilise le nbre de jour sur le mois de novembre alors que je voudrai que cela soit réparti sur les 2 mois.

    Y a t il une méthode particulière pour la répartition se fasse correctement ?

    Par avance merci pour votre aide.

  2. #2
    Membre actif
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    novembre 2016
    Messages
    183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : novembre 2016
    Messages : 183
    Points : 270
    Points
    270
    Par défaut
    Salut !

    Photo pour illustrer ?

    Tu as bien mis ton mois en axe d'analyse ?

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut
    Je n'ai pas de photo.

    je vais essayer d'être clair dans mes explications :

    dans mon calendrier, j'ai créé 3 colonnes
    Jours ouvrés Temp = IF(OR (FORMAT('Calendar'[Date],"dddd")="Dimanche",FORMAT('Calendar'[Date],"dddd")="Samedi"),0,1) => pour exclure les samedi et dimanche
    Jours Fériés = LOOKUPVALUE('Jours Fériés'[Nbre],'Jours Fériés'[Jours Fériés],'Calendar'[Date]) => pour intégrer les jours fériés
    Jours Ouvrés = IF('Calendar'[Jours Ouvrés Temp]=1,'Calendar'[Jours Ouvrés Temp]-'Calendar'[Jours Fériés],0) => pour avoir uniquement les jours à prendre en compte

    et j'ai créé une mesure pour calculer le nombre de jours ouvrés de la période :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    NbJourouvrés = 
    CALCULATE(SUM('Calendar'[Jours Ouvrés]),DATESBETWEEN('Calendar'[Date],Table1[Date de début],Table1[Date de fin]))
    Le résultat est bon, par contre lorsque je positionne cette mesure dans un histogramme, il me donne le résultat que sur le mois correspondant à la date de début.

    Si je met l'intervalle du 14/11/2020 au 18/12/2020, il va me calculer X jours et ils vont être indiquer sur le mois de Novembre et j'ai bien mis le mois en axe d'analyse.

    Alors peut être que la mesure que j'ai construite n'est pas celle que je dois mettre en place.

    si vous avez des pistes, je suis preneur.

    Merci.

  4. #4
    Membre actif
    Homme Profil pro
    Ctrl Gestion
    Inscrit en
    octobre 2011
    Messages
    130
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ctrl Gestion
    Secteur : Industrie

    Informations forums :
    Inscription : octobre 2011
    Messages : 130
    Points : 260
    Points
    260
    Par défaut
    Bonjour,

    Un essai ou une piste de recherche :
    1- en créant dans la requête Power query, deux colonnes comme suit :
    - Menu ajouter une colonne, on clique sur la colonne de fin puis sur la colonne de début en maintenant la touche CTRL appuyée et en allant dans le menu Date, option Soustraction on obtient l'instruction suivante qui donne le nombre de jours entre les deux dates.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = Table.AddColumn(#"Type modifié", "Soustraction", each Duration.Days([End Date] - [Start Date]), Int64.Type)
    - Menu Ajouter une colonne, Colonne personnalisée, on va créer une liste de dates comprise entre la date de début et la date de fin. soustraction est la colonne créée préalablement.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = Table.AddColumn(#"Soustraction de la date d'insertion", "DatesInPeriode", each List.Dates([Start Date],[Soustraction]+1,#duration(1,0,0,0)))
    2 - on peut maintenant supprimer la colonne Soustraction.
    3 - Charger les données

    Dans Power BI, on va créer une relation entre la table des données et la table des dates (calendrier), sur la colonne "DatesInPeriode" (dernière colonne créée en Power Query)
    Puis on va créer notre mesure Nb_Jours comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Nb_JT = CALCULATE(sum(dimDates[Jours travaillés]), filter(tabData,tabData[DatesInPeriode]<=max(dimDates[Date])))
    Cela me donne le résultat suivant
    Nom : JoursTravaillés.JPG
Affichages : 21
Taille : 23,5 Ko

    Pas trouvé mieux, certainement améliorable ou possible de faire autrement.
    Cordialement
    DanixDB

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut
    Bonjour,

    Merci pour cette aide.

    Donc ce que j'ai compris et réaliser suite à vos instruction :

    1. Ajouter la colonne soustraction
    2. Ajouter la colonne DatesInPeriode
    3. Création de la relation entre mon calendier date et mes datas sur la date de début
    4. Création de la mesure, j'ai créé la mesure suivant les instructions
    Votre mesure
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Nb_JT = CALCULATE(sum(dimDates[Jours travaillés]), filter(tabData,tabData[DatesInPeriode]<=max(dimDates[Date])))
    Ma mesure
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NbJourOuvrés = CALCULATE(sum('Calendar'[Jours Ouvrés]), filter(Data,Data2021[DatesInPeriode]<=max('Calendar'[Date])))
    J'ai mis ma colonne Jours Ouvrés qui me calcul le nombre de jours ouvrés dans le calendrier, car j'exclus les samedi/Dimanche et jours fériés et ensuite, je reprends le reste de la mesure qui est sensiblement identique.

    le message qui apparait et impossible d'afficher l'élément visuel, en gros j'ai un problème de format text et date, lorsque je regarde la colonne DatesInPeriode dans Power Query, le format est en texte, et je ne peux pas le convertir.


    Est ce que j'aurai oublié quelque chose ?

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut
    si je développe la colonne DateInpériode, et que je convertis les données en date, ma mesure fonctionne.

    Donc je pense que je suis obligé de développer cette colonne ? est ce que l'on peut faire sans ou on est obligé de le faire ?

    Par avance merci.

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut
    Donc ma mesure fonctionne, mais le résultat est vide. Donc je pense qu'il ne faut pas développer la colonne DateInPeriode.

    Je sèche mais continue de chercher.

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    mars 2007
    Messages
    257
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : mars 2007
    Messages : 257
    Points : 106
    Points
    106
    Par défaut
    En fait,

    J'ai développé dans power query date in period, je l'ai mis au format date, je suis retourné dans Power bi est j'ai mis la relation à jour calendrier (date) vers date in period.

    C'était écrit dans le descriptif, j'ai pas bien lu.

    Encore merci danixdb

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 01/12/2018, 11h15
  2. Nbre de jours ouvrés entre deux date
    Par lito74 dans le forum Access
    Réponses: 3
    Dernier message: 08/12/2005, 09h16
  3. Comment utiliser la fonction NBR.JOURS.OUVRES?
    Par MEHCOOPER dans le forum Access
    Réponses: 9
    Dernier message: 20/10/2005, 12h50
  4. Compter le nb de jours ouvrés entre 2 dates
    Par bugmenot dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 15/09/2005, 13h19
  5. [Info] Jours ouvrés entre 2 dates
    Par Dinytro dans le forum API standards et tierces
    Réponses: 14
    Dernier message: 10/08/2005, 16h05

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