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 :

Paramètre dynamique en fonction d'un champ date d'une table - Power query Excel


Sujet :

POWER

  1. #1
    Membre à l'essai
    Femme Profil pro
    Chargé études
    Inscrit en
    Juin 2022
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chargé études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2022
    Messages : 22
    Points : 16
    Points
    16
    Par défaut Paramètre dynamique en fonction d'un champ date d'une table - Power query Excel
    Bonjour à tous,

    Je vais essayer d'être la plus claire possible...

    J'ai importé une table t_historisee et une table t_depot dans un power query d'excel.
    t_historisee = données sur des entrées de locataires de 2018 à aout 2022 (1 ligne = une entrée)
    t_depot = données sur des entrées de locataires de janv à sept 2022 (1 ligne = 1 entrée)

    Je souhaite supprimer les lignes de la table_historisée correspondants à la période couverte par la table t_depot.

    Donc dans mon cas : je veux supprimer les lignes de la table t_historisee avec une date de début d'occupation comprise entre le 01/01/2022 et le 31/08/2022
    puis je souhaite ajouter les données de la table t_depot (données du 01/01/2022 au 30/09/2022)
    Ceci sera répété chaque mois : par exemple le mois prochain, je devrais supprimer les lignes de la table t_historisee avec une date de début d'occupation comprise entre le 01/01/2022 et 30/09/2022
    puis ajouter les données de la table t_depot du 01/01/2022 au 31/10/2022...etc...


    J'essaye de créer un paramètre dynamique qui irait chercher l'année dans la date de début d'occupation de la table t_depot.
    Puis de filtrer le champs "date de début d'occupation" de la table historisee en lui disant de ne pas prendre les lignes avec une année égale à celle de mon paramètre.

    En faisant cela, je veux éviter un paramètre figé ou à modifier manuellement chaque année.
    Précision la table t_depot est une table en année civil donc il ne peut pas y avoir d'années différentes.

    Merci d'avance pour toute votre aide!
    Là je suis partie sur cette idée de paramètre mais toute autre astuce est la bienvenue!!!

  2. #2
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 530
    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 530
    Points : 16 473
    Points
    16 473
    Par défaut
    Bonjour

    Pas besoin de paramètres : il suffit de croiser les deux table pour repérer les communs puis les éliminer d'histo

    Éventuellement poste un fichier avec quelques lignes représentatives de chaque table

  3. #3
    Membre expérimenté
    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    667
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 667
    Points : 1 432
    Points
    1 432
    Par défaut
    Bonjour,

    Sélectionner dans t_historisee les lignes dont l'année est différente de l'année en cours suffirait, sans croisement. C'est peut-être plus accessible (?).

    ça pourrait ressembler à ça (en supposant que la colonne pour laquelle il faut appliquer le filtrage s'appelle "ColonneDate"):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = Table.SelectRows(#"EtapePrécédentePour t_historisee", each Date.Year([ColonneDate]) <> Date.Year(DateTime.LocalNow()))
    Il ne reste alors qu'à combiner les deux tables (bouton "ajouter des requêtes").

  4. #4
    Membre à l'essai
    Femme Profil pro
    Chargé études
    Inscrit en
    Juin 2022
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chargé études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2022
    Messages : 22
    Points : 16
    Points
    16
    Par défaut
    Merci de vos réponses.

    Je ne peux pas croiser les tables car ce ne sont pas des doublons.
    Dans la t_depot, que je récupère chaque mois, les entrées locataires bougent (annulation, décalage dans les dates, nouvelle entrée) même sur des mois passés.

    Il faut absolument que je supprime les lignes de t_historisee dont la période des dates d'entrées est la même que t_depot PUIS coller les lignes de t_depot. Un annule et remplace!

    Ta solution Promethee25 serait presque parfaite : car là on parle de l'année en cours mais quand je serai en janvier 2023, t_historisee contiendra des données de Janvier à Novembre 2022.
    La t_depot les données de janvier à decembre 2022.
    Et je voudrai donc lui dire supprime les lignes de t_historisee (de 2022) puis ajouter les données de t_depot. Or je ne suis pas sur une année en cours mais en 2023.

    C'est pourquoi je pensais à un paramètre dynamique. J'aimerai pouvoir dire si annee de t_historisee = annee de t_depot alors on supprime les lignes de t_historisee avec cette année en commun.

  5. #5
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 530
    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 530
    Points : 16 473
    Points
    16 473
    Par défaut
    Bonjour

    Pour ma part j'ajoute une colonne Année au 2 tables et je croise

    t_depot
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    let
        Source = Excel.CurrentWorkbook(){[Name="t_depot"]}[Content],
        #"Type modifié" = Table.TransformColumnTypes(Source,{{"Date", type date}}}),
        #"Année insérée" = Table.AddColumn(#"Type modifié", "Année", each Date.Year([Date]), Int64.Type)
    in
        #"Année insérée"
    t_historisee
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    let
        Source = Excel.CurrentWorkbook(){[Name="t_historisee"]}[Content],
        #"Type modifié" = Table.TransformColumnTypes(Source,{{"Date", type date}}),
        #"Année insérée" = Table.AddColumn(#"Type modifié", "Année", each Date.Year([Date]), Int64.Type),
        #"Requêtes fusionnées" = Table.NestedJoin(#"Année insérée", {"Année"}, t_depot, {"Année"}, "t_depot", JoinKind.LeftOuter),
        #"t_depot développé" = Table.ExpandTableColumn(#"Requêtes fusionnées", "t_depot", {"Année"}, {"Année.1"}),
        #"Lignes filtrées" = Table.SelectRows(#"t_depot développé", each ([Année.1] = null)),
        #"Colonnes supprimées" = Table.RemoveColumns(#"Lignes filtrées",{"Année.1"})
    in
        #"Colonnes supprimées"
    ou plus direct
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    let
        Source = Excel.CurrentWorkbook(){[Name="t_historisee"]}[Content],
        #"Type modifié" = Table.TransformColumnTypes(Source,{{"Date", type date}}),
        #"Année insérée" = Table.AddColumn(#"Type modifié", "Année", each Date.Year([Date]), Int64.Type),
        #"Requêtes fusionnées" = Table.NestedJoin(#"Année insérée", {"Année"}, t_depot, {"Année"}, "t_depot", JoinKind.LeftAnti),
        #"Colonnes supprimées" = Table.RemoveColumns(#"Requêtes fusionnées",{"t_depot"})
    in
        #"Colonnes supprimées"

  6. #6
    Membre expérimenté
    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    667
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 667
    Points : 1 432
    Points
    1 432
    Par défaut
    Bonjour,

    Il devrait suffire de se baser sur l'année du mois précédent:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = Table.SelectRows(#"EtapePrécédentePour t_historisee", each Date.Year([ColonneDate]) <> Date.Year(Date.AddMonth(DateTime.LocalNow(), -1)))

  7. #7
    Membre à l'essai
    Femme Profil pro
    Chargé études
    Inscrit en
    Juin 2022
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chargé études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2022
    Messages : 22
    Points : 16
    Points
    16
    Par défaut
    Je suis désolée mais je ne comprends pas votre solution...
    Je débute donc ce n'est pas encore évident.

    t_depot et t_historiséee je fusionne à partir de la t_historisee via le champs "Année"?
    En fait je ne comprends pas pourquoi on fait cela? et en quoi cela va me supprimer les lignes de la t_historisee pour ne garder que les lignes de la t_depot.

  8. #8
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 530
    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 530
    Points : 16 473
    Points
    16 473
    Par défaut
    RE

    J'imagine que tu t'adresses à moi ?

    As-tu essayé de recopier le code dans l'éditeur avancé ?

    Crée une requête vide, ouvre l'éditeur avancé et copie le 1er code puis après validation nomme-la t_depot

    Fait de même pour t_historisee avec le 3ème code

    Tu pourras alors visualiser les étapes de façon détaillée

    Je poste aussi un exemple simple
    Fichiers attachés Fichiers attachés

  9. #9
    Membre à l'essai
    Femme Profil pro
    Chargé études
    Inscrit en
    Juin 2022
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chargé études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2022
    Messages : 22
    Points : 16
    Points
    16
    Par défaut
    C'est bon j'ai enfin compris!! Il faut que je maitrise mieux les types de jointure. Je n'avais jusqu'à présent utilisé que "interne".

    Merci pour ta patience et ton exemple!!! Je vais corriger et tester si çà marche.

Discussions similaires

  1. Réponses: 1
    Dernier message: 15/03/2015, 18h44
  2. [AC-2013] Table variable en fonction d'un champ date
    Par choupi_oc dans le forum Access
    Réponses: 4
    Dernier message: 20/10/2014, 15h40
  3. Affichage dynamique en fonction d'un champ et la date courante
    Par Catarssis dans le forum Développement Sharepoint
    Réponses: 2
    Dernier message: 10/04/2013, 13h51
  4. Champs date sur une page web
    Par jpdolloils dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 17/07/2006, 14h13
  5. Regrouper une sélection en fonction d'un champ et d'une date
    Par 12_darte_12 dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 29/03/2006, 18h12

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