Need help creating a Power query on alphabetical range

Richard U

Active Member
Joined
Feb 14, 2006
Messages
406
Office Version
  1. 365
  2. 2016
  3. 2010
  4. 2007
Platform
  1. Windows
I know I'm missing something really simple:

How can I do a query where I can return records based on customer names. In other words, something that would return all customer names staring with 1 to j, or K to P or N to Z
 

Excel Facts

Create a Pivot Table on a Map
If your data has zip codes, postal codes, or city names, select the data and use Insert, 3D Map. (Found to right of chart icons).
M code in CustomerData Query (relies on FromTo table loaded as connection only):

Power Query:
let
    Source = Excel.CurrentWorkbook(){[Name="CustomerData"]}[Content],
    #"Added Custom" = Table.AddColumn(Source, "Custom", each Character.ToNumber([Name])),
    #"Added Conditional Column" = Table.AddColumn(#"Added Custom", "Custom.1", each if [Custom] >= Character.ToNumber(FromTo{0}[From]) then true else false),
    #"Added Conditional Column1" = Table.AddColumn(#"Added Conditional Column", "Custom.2", each if [Custom] <= Character.ToNumber(FromTo{0}[To]) then true else false),
    #"Removed Columns" = Table.RemoveColumns(#"Added Conditional Column1",{"Custom"}),
    #"Filtered Rows" = Table.SelectRows(#"Removed Columns", each ([Custom.1] = true) and ([Custom.2] = true)),
    #"Removed Columns1" = Table.RemoveColumns(#"Filtered Rows",{"Custom.1", "Custom.2"})
in
    #"Removed Columns1"

1615337045125.png
 
Upvote 0
I'm very new to PQ, I see the results, but I don't understand what the M code is doing, or how I would modify it for my purposes. Could you please explain a bit?
 
Upvote 0
Source = Excel.CurrentWorkbook(){[Name="[/COLOR][COLOR=rgb(44, 130, 201)][B]CustomerData[/B][/COLOR][COLOR=rgb(226, 80, 65)]"]}[Content],
takes the data from the current workbook from a table named CustomerData (change to your table name) and assigns it a name Source

#"Added Custom" = Table.AddColumn(Source, "Custom", each Character.ToNumber([Name])),
adds a column to the Source data table containing the ascii code for the first character in each cell in column Name (change Name to the appropriate column name in your table)
and calls the new column Custom and the resulting table #"Added Custom"

#"Added Conditional Column" = Table.AddColumn(#"Added Custom", "Custom.1", each if [Custom] >= Character.ToNumber(FromTo{0}[From]) then true else false),
Adds a column to the #"Added Custom" table based on a condition that the ascii value in Custom is greater than or equal to the From number from table FromTo (with columns From and To) that has been loaded as a connection only (Change FromTo to whatever you named your FromTo table) if condition is true it puts true in the new column called Custom.1 otherwise false

#"Added Conditional Column1" = Table.AddColumn(#"Added Conditional Column", "Custom.2", each if [Custom] <= Character.ToNumber(FromTo{0}[To]) then true else false),
Similar to the above step but true if less than or equal to the To value in Table FromTo

#"Removed Columns" = Table.RemoveColumns(#"Added Conditional Column1",{"Custom"}),
Remove the Custom column from step 2 since we don't need it

#"Filtered Rows" = Table.SelectRows(#"Removed Columns", each ([Custom.1] = true) and ([Custom.2] = true)),
Filers the table to only those rows that have true in Custom.1 AND Custom.2

#"Removed Columns1" = Table.RemoveColumns(#"Filtered Rows",{"Custom.1", "Custom.2"})
Remove Custom.1 and Custom.2 because we no longer need them

So this query relies on two tables in Excel. In my example the large table is called CustomerData and the small Table is called FromTo. Both have to be inputted into power query for it to work. The text in bold blue needs to be changed to match your table names and Column names.
 
Upvote 0

Forum statistics

Threads
1,225,626
Messages
6,186,087
Members
453,336
Latest member
Excelnoob223

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top