APQ09: Advanced Power Query | Exact match lookup in Power Query | No Merge Queries

Поділитися
Вставка
  • Опубліковано 6 січ 2025

КОМЕНТАРІ • 40

  • @DhruvDua88
    @DhruvDua88 5 місяців тому +1

    You have explained very succintly, and this is one of the easiest videos to understand look up in Powerquery

  • @glostermeteor2
    @glostermeteor2 Рік тому +1

    These PQ videos are really good, some of the best I've seen on YT. I've been using PQ for a couple of years now so they are pitched right at my level and full of useful techniques. Thank you.

    • @AAAExcel
      @AAAExcel  Рік тому

      Happy that you found them useful ☺️

  • @ebf6562
    @ebf6562 Рік тому +2

    Génial, merci beaucoup! Vous êtes un excellent professeur.

    • @AAAExcel
      @AAAExcel  Рік тому

      Avec plaisir, merci pour ton gentil commentaire

  • @zahoorsarbandi2982
    @zahoorsarbandi2982 Рік тому +1

    both techniques are superb. Thank you for sharing your valuable knowledge.

  • @danthompson8309
    @danthompson8309 Рік тому

    Thank you so much. Excellent overview of examples. It’s been hard to find videos with these deeper examples.

  • @boissierepascal5755
    @boissierepascal5755 Рік тому

    Very helpful and interesting 👌🏽

  • @kennethstephani692
    @kennethstephani692 11 днів тому

    Terrific video!!

  • @SaleemShouket-r3p
    @SaleemShouket-r3p 4 місяці тому

    Great

    • @AAAExcel
      @AAAExcel  4 місяці тому

      Thank you 🙏

  • @kishorpanara4191
    @kishorpanara4191 Рік тому

    Awesome

  • @MichaelVB226
    @MichaelVB226 Рік тому +3

    Are there any significant performance issue differences with the use of either technique? Thank you for your expertise! I enjoyed the video!

    • @AAAExcel
      @AAAExcel  Рік тому +1

      This question needs more investigation, I did a quick search, but i found a comparison between merge and List.PositionOf, although List.PositionOf result in less steps and cleaner code, some opinions say that merge is still faster. Also, it's recommended to use Table.Buffer if you are working with larger data sets to enhance performance.

    • @mz2433
      @mz2433 Рік тому

      @@AAAExcel Hi Amr, would you please walk us through Table.Buffer in a separate video? Thank you very much!!

    • @AAAExcel
      @AAAExcel  Рік тому +1

      Will consider 👍

  • @johnwabaki7125
    @johnwabaki7125 Рік тому

    Appreciate it 👌

  • @leetran8328
    @leetran8328 3 місяці тому

    tks u

  • @mostafafarag8078
    @mostafafarag8078 10 місяців тому

    Hello
    I have an inquiry , is there any method to link the record with a pdf like a hyperlink?

    • @AAAExcel
      @AAAExcel  8 місяців тому

      I found this in "Fabric Comunity", it may help
      community.fabric.microsoft.com/t5/Power-Query/Add-Hyperlink-to-a-cell-column-in-Power-Query/m-p/3440263

  • @ebf6562
    @ebf6562 Рік тому

    Hello. How can we use a Query converted in function in List.PositionOf? Thank you very much

    • @AAAExcel
      @AAAExcel  Рік тому

      i think it is doable, you can use variable inside the List.PositionOf, but no example in my mind for now. i have several videos discussing custom functions, like the one talking about running totals, you can check the following link:
      ua-cam.com/video/TN6y8bvUt_g/v-deo.html

  • @roywilson9580
    @roywilson9580 Рік тому +1

    Thank you for the interesting video. I have no real preference for the method of obtaining results, though I think I would add a list buffer statement to the lists if the dataset was particularly large. Having worked with several people who love click the gear icon, change things and break perfectly good queries I would make the following update to the metod to remove the gear icon from the last function in the query and thus, hopefully, stop changes being made by colleagues who don't understand what they are playing with:
    let
    Source = Excel.CurrentWorkbook(){[Name="Sales"]}[Content],
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Customer ID", Int64.Type}, {"Product ID", Int64.Type}, {"Quantity", Int64.Type}}),
    FinalReport = let
    a = Table.AddColumn(
    #"Changed Type",
    "Customer Name",
    each Customer{
    List.PositionOf(
    Customer[Customer ID],
    [Customer ID]
    )
    }[Customer Name],
    type text
    ),
    b = Table.AddColumn(
    a,
    "Revenue",
    each Price{
    [Product ID = [Product ID]]
    }
    [Price] * [Quantity],
    type number
    ),
    c = Table.Group(
    b,
    { "Customer Name" },
    { { "Revenue", each List.Sum( [Revenue] ), type number } }
    )
    in c
    in
    FinalReport
    Then I would hide the formula bar in optioins just to be on the safe side.

    • @AAAExcel
      @AAAExcel  Рік тому +1

      nice, thank you for the useful contribution

    • @osoriomatucurane9511
      @osoriomatucurane9511 Місяць тому

      This paradigm is an awesome trick indeed. Grouping the transformation steps into nested let in statments. In addition to safety advantages from hiding the gear icon, we could keep the transformation process transparent , informative, resulting in compact displayed steps as well as a better structured and much more readible code.
      Here I have tweaked your code as follows:
      Let
      Source(....),
      //------------
      MergeCustomerName = let
      LookUpName = Table.AddColumn(Source, .....)
      in LookUpName,
      //-----------------
      MergePrice = let
      LookUpPrice = AddColumn(......)
      in LookUpPrice,
      // -----------------
      Grouping = let
      Revenue = AddColumn(.....),
      GroupedRevenue = Table.Group(....),
      SortedRevenue = Table.Sort(...)
      in SortedRevenue,
      in
      Grouping
      -------------
      In this structured way, the displayed visible steps renamed meaningful will be
      1.Source
      2. MergedCustomerName
      3. MergedPrice
      4. Grouping
      Final Note. The Data Types could be changed along embbeded in the Table.AddColumn(), Table.TansformationColumn(), or relying on the data type coersing functions or separetly using the Table.TransformColumnTypes() in each grouped steps.

  • @amoserene1553
    @amoserene1553 9 місяців тому

    Thank you! But a question, if Customer Id is not defined in customer name then error is showing.

    • @AAAExcel
      @AAAExcel  8 місяців тому

      you can solve this issue using try and otherwise
      I have a video explaining how to use it:
      ua-cam.com/video/M6KvIDoLsQE/v-deo.html

    • @osoriomatucurane9511
      @osoriomatucurane9511 2 місяці тому

      Do you mean, if there is no match (a given customer that has not made one single purchase, therefore not recorded in the sales table) we get an error for that row/record. Correct?

  • @aymanabuelmaged7230
    @aymanabuelmaged7230 Рік тому

    Happy Eid Al-Fitr to you, my teacher 🎉 . I would like to thank you and express my gratitude for this generous Wonderful and unique content
    And I under your permission ask if there is nothing in the lookup table that match the other table, is it possible to use "if statement" or better "try and otherwise", appreciate your patience. ❤

    • @AAAExcel
      @AAAExcel  Рік тому

      Happy Eid Ayman, thank you so much for your kind words. Absolutely right, can't agree more

  • @sdr5593
    @sdr5593 Рік тому

    How would you solve the following problem?
    I have a table called budgetsales.
    It is the forecast sales for the upcoming year by customer and product type. In total around 300 rows.
    There are then columns for revenue, volume, gross profit, freight cost, overhead cost and net profit.
    The annual budget table needs to be split into monthly numbers with the phasing different per month. Q1 months = 7.333% each, Q2 months = 8.3333% each, Q3 months = 8.3333% each and Q4 months = 9.3333% each.
    The fiscal year starts on 1st June
    The monthly phasing needs to be applied to all months as per above.
    So June sales volume = annual sales volume X 7.33333%. same for GP, volume etc
    September sales revenue = annual sales revenue x 8.3333%
    And so on......
    The output should be a table than can be analysed with a pivot table.

    • @AAAExcel
      @AAAExcel  Рік тому +1

      Create a table with the monthly allocation %, reference it inside the budget table, then expand the table. you will have the table expanded to include a month column, multiply all columns containing numbers (i.e. sales, cost, profit, etc..) by the % came from the new table (one by one). then you are good to go