Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Calling all Data Engineers! Fabric Data Engineer (Exam DP-700) live sessions are back! Starting October 16th. Sign up.

Reply
kevinbala
New Member

How to Extract 3 columnns from a column

Hi All,

 

I need some help with the data im working on, I'm trying to breakdown a column into three new columns on PowerBI

 

4437e54f-4fbd-4ca1-8c09-21e243a24d82.png

Conditions

  1. if the characters starts with a Letter, it moves to the Left, else leave it blank
  2. If the character ends with a W, then move it to the Right
  3. extract the numbers in between
  4. get rid of the '%'

 

1 ACCEPTED SOLUTION
Vijay_A_Verma
Super User
Super User

See the working here - Open a blank query - Home - Advanced Editor - Remove everything from there and paste the below code to test

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WcrEwC1eK1YlWcjQxhdAWFhABCwtVqIApVIWZGZg2N4DwLS1VoQohlCVEGGJiLAA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Default Header" = _t]),
    #"Added Custom" = Table.AddColumn(Source, "Actual%", each Text.Select([Default Header],{"0".."9"}), type number),
    #"Added Custom1" = Table.AddColumn(#"Added Custom", "Left", each if List.Contains({"A".."Z"},Text.Start([Default Header],1)) then Text.Start([Default Header],1) else null, type text),
    #"Added Custom2" = Table.AddColumn(#"Added Custom1", "Right", each if Text.EndsWith([Default Header],"W") then "W" else null, type text)
in
    #"Added Custom2"

View solution in original post

1 REPLY 1
Vijay_A_Verma
Super User
Super User

See the working here - Open a blank query - Home - Advanced Editor - Remove everything from there and paste the below code to test

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WcrEwC1eK1YlWcjQxhdAWFhABCwtVqIApVIWZGZg2N4DwLS1VoQohlCVEGGJiLAA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Default Header" = _t]),
    #"Added Custom" = Table.AddColumn(Source, "Actual%", each Text.Select([Default Header],{"0".."9"}), type number),
    #"Added Custom1" = Table.AddColumn(#"Added Custom", "Left", each if List.Contains({"A".."Z"},Text.Start([Default Header],1)) then Text.Start([Default Header],1) else null, type text),
    #"Added Custom2" = Table.AddColumn(#"Added Custom1", "Right", each if Text.EndsWith([Default Header],"W") then "W" else null, type text)
in
    #"Added Custom2"

Helpful resources

Announcements
FabCon Global Hackathon Carousel

FabCon Global Hackathon

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!

September Power BI Update Carousel

Power BI Monthly Update - September 2025

Check out the September 2025 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.

Top Kudoed Authors