A
- AccessControlEntry.ConditionToIdentities
- Access.Database
- ActiveDirectory.Domains
- AdobeAnalytics.Cubes
- AdoDotNet.DataSource
- AdoDotNet.Query
- AnalysisServices.Database
- AnalysisServices.Databases
- AzureStorage.BlobContents
- AzureStorage.Blobs
- AzureStorage.DataLake
- AzureStorage.DataLakeContents
- AzureStorage.Tables
B
- BinaryFormat.Binary
- BinaryFormat.Byte
- BinaryFormat.ByteOrder
- BinaryFormat.Choice
- BinaryFormat.Decimal
- BinaryFormat.Double
- BinaryFormat.Group
- BinaryFormat.Length
- BinaryFormat.List
- BinaryFormat.Null
- BinaryFormat.Record
- BinaryFormat.SignedInteger16
- BinaryFormat.SignedInteger32
- BinaryFormat.SignedInteger64
- BinaryFormat.Single
- BinaryFormat.Text
- BinaryFormat.Transform
- BinaryFormat.UnsignedInteger16
- BinaryFormat.UnsignedInteger32
- BinaryFormat.UnsignedInteger64
- BinaryFormat.7BitEncodedSignedInteger
- BinaryFormat.7BitEncodedUnsignedInteger
- Binary data
- Binary.ApproximateLength
- Binary.Buffer
- Binary.Combine
- Binary.Compress
- Binary.Decompress
- Binary.From
- Binary.FromList
- Binary.FromText
- Binary.InferContentType
- Binary.Length
- Binary.Range
- Binary.Split
- Binary.ToList
- Binary.ToText
- Binary.View
- Binary.ViewError
- Binary.ViewFunction
- Byte.From
C
- Cdm.Contents
- Character.FromNumber
- Character.ToNumber
- Combiner.CombineTextByDelimiter
- Combiner.CombineTextByEachDelimiter
- Combiner.CombineTextByLengths
- Combiner.CombineTextByPositions
- Combiner.CombineTextByRanges
- Comparer.FromCulture
- Comparer.Ordinal
- Comparer.OrdinalIgnoreCase
- Controlling byte order
- Csv.Document
- Cube.AddAndExpandDimensionColumn
- Cube.AddMeasureColumn
- Cube.ApplyParameter
- Cube.AttributeMemberId
- Cube.AttributeMemberProperty
- Cube.CollapseAndRemoveColumns
- Cube.Dimensions
- Cube.DisplayFolders
- Cube.MeasureProperties
- Cube.MeasureProperty
- Cube.Measures
- Cube.Parameters
- Cube.Properties
- Cube.PropertyKey
- Cube.ReplaceDimensions
- Cube.Transform
- Currency.From
D
- DateTime.AddZone
- DateTime.Date
- DateTime.FixedLocalNow
- DateTime.From
- DateTime.FromFileTime
- DateTime.FromText
- DateTime.IsInCurrentHour
- DateTime.IsInCurrentMinute
- DateTime.IsInCurrentSecond
- DateTime.IsInNextHour
- DateTime.IsInNextMinute
- DateTime.IsInNextNHours
- DateTime.IsInNextNMinutes
- DateTime.IsInNextNSeconds
- DateTime.IsInNextSecond
- DateTime.IsInPreviousHour
- DateTime.IsInPreviousMinute
- DateTime.IsInPreviousNHours
- DateTime.IsInPreviousNMinutes
- DateTime.IsInPreviousNSeconds
- DateTime.IsInPreviousSecond
- DateTime.LocalNow
- DateTime.Time
- DateTime.ToRecord
- DateTime.ToText
- Date.AddDays
- Date.AddMonths
- Date.AddQuarters
- Date.AddWeeks
- Date.AddYears
- Date.Day
- Date.DayOfWeek
- Date.DayOfWeekName
- Date.DayOfYear
- Date.DaysInMonth
- Date.EndOfDay
- Date.EndOfMonth
- Date.EndOfQuarter
- Date.EndOfWeek
- Date.EndOfYear
- Date.From
- Date.FromText
- Date.IsInCurrentDay
- Date.IsInCurrentMonth
- Date.IsInCurrentQuarter
- Date.IsInCurrentWeek
- Date.IsInCurrentYear
- Date.IsInNextDay
- Date.IsInNextMonth
- Date.IsInNextNDays
- Date.IsInNextNMonths
- Date.IsInNextNQuarters
- Date.IsInNextNWeeks
- Date.IsInNextNYears
- Date.IsInNextQuarter
- Date.IsInNextWeek
- Date.IsInNextYear
- Date.IsInPreviousDay
- Date.IsInPreviousMonth
- Date.IsInPreviousNDays
- Date.IsInPreviousNMonths
- Date.IsInPreviousNQuarters
- Date.IsInPreviousNWeeks
- Date.IsInPreviousNYears
- Date.IsInPreviousQuarter
- Date.IsInPreviousWeek
- Date.IsInPreviousYear
- Date.IsInYearToDate
- Date.IsLeapYear
- Date.Month
- Date.MonthName
- Date.QuarterOfYear
- Date.StartOfDay
- Date.StartOfMonth
- Date.StartOfQuarter
- Date.StartOfWeek
- Date.StartOfYear
- Date.ToRecord
- Date.ToText
- Date.WeekOfMonth
- Date.WeekOfYear
- Date.Year
- DB2.Database
- Decimal.From
- Diagnostics.ActivityId
- Diagnostics.Trace
- DirectQueryCapabilities.From
- Double.From
- Duration.Days
- Duration.From
- Duration.FromText
- Duration.Hours
- Duration.Minutes
- Duration.Seconds
- Duration.ToRecord
- Duration.TotalDays
- Duration.TotalHours
- Duration.TotalMinutes
- Duration.TotalSeconds
- Duration.ToText
E
F
G
H
I
L
- Lines.FromBinary
- Lines.FromText
- Lines.ToBinary
- Lines.ToText
- List.Accumulate
- List.AllTrue
- List.Alternate
- List.AnyTrue
- List.Average
- List.Buffer
- List.Combine
- List.ConformToPageReader
- List.Contains
- List.ContainsAll
- List.ContainsAny
- List.Count
- List.Covariance
- List.Dates
- List.DateTimes
- List.DateTimeZones
- List.Difference
- List.Distinct
- List.Durations
- List.FindText
- List.First
- List.FirstN
- List.Generate
- List.InsertRange
- List.Intersect
- List.IsDistinct
- List.IsEmpty
- List.Last
- List.LastN
- List.MatchesAll
- List.MatchesAny
- List.Max
- List.MaxN
- List.Median
- List.Min
- List.MinN
- List.Mode
- List.Modes
- List.NonNullCount
- List.Numbers
- List.Percentile
- List.PositionOf
- List.PositionOfAny
- List.Positions
- List.Product
- List.Random
- List.Range
- List.RemoveFirstN
- List.RemoveItems
- List.RemoveLastN
- List.RemoveMatchingItems
- List.RemoveNulls
- List.RemoveRange
- List.Repeat
- List.ReplaceMatchingItems
- List.ReplaceRange
- List.ReplaceValue
- List.Reverse
- List.Select
- List.Single
- List.SingleOrDefault
- List.Skip
- List.Sort
- List.Split
- List.StandardDeviation
- List.Sum
- List.Times
- List.Transform
- List.TransformMany
- List.Union
- List.Zip
- Logical.From
- Logical.FromText
Understanding the Combiner.CombineTextByDelimiter Function
The Combiner.CombineTextByDelimiter function is used to combine multiple columns of text into a single column separated by a delimiter. The function takes three arguments: the delimiter, the columns to combine, and an optional parameter to specify the output column name.
Here is an example of how the function works:
= Table.AddColumn(#”PreviousStep”, “Combined”, each Combiner.CombineTextByDelimiter(“, “, {“Column1”, “Column2”, “Column3”}))
In this example, we are adding a new column called "Combined" to a table called "PreviousStep". The new column will combine the values from columns "Column1", "Column2", and "Column3" separated by a comma and a space.
The M Code Behind Combiner.CombineTextByDelimiter
The M code behind the Combiner.CombineTextByDelimiter function is straightforward and easy to understand. Here is the M code for the function:
let
CombineTextByDelimiter = (delimiter as text, columns as list, optional separator as text) as text =>
let
separator = if separator = null then “” else separator,
columnValues = List.Transform(columns, each Text.From(_)),
result = Text.Combine(columnValues, delimiter & separator)
in
result
in
CombineTextByDelimiter
The code starts with a function called "CombineTextByDelimiter" that takes three parameters: delimiter, columns, and optional separator. The function then checks if the separator parameter is null, and if so, sets it to an empty string.
Next, the function uses the List.Transform function to convert each column in the columns parameter to a text value. This is necessary because the Combiner.CombineTextByDelimiter function can only combine text values.
Finally, the function uses the Text.Combine function to combine the text values from the columns parameter using the delimiter and separator parameters.
Using Combiner.CombineTextByDelimiter for Data Cleaning
The Combiner.CombineTextByDelimiter function can be used for a variety of data cleaning tasks. Here are some examples:
Combining First and Last Names
Suppose you have a table with separate columns for first and last names, and you want to combine them into a single column. You can use the Combiner.CombineTextByDelimiter function to do this:
= Table.AddColumn(#”PreviousStep”, “Full Name”, each Combiner.CombineTextByDelimiter(” “, {“First Name”, “Last Name”}))
In this example, we are adding a new column called "Full Name" to a table called "PreviousStep". The new column will combine the values from columns "First Name" and "Last Name" separated by a space.
Removing Duplicates in a Column
Suppose you have a column that contains duplicate values, and you want to remove the duplicates. You can use the Combiner.CombineTextByDelimiter function to do this:
= Table.AddColumn(#”PreviousStep”, “Unique Column”, each List.Distinct(Text.Split([Column], “,”)))
In this example, we are adding a new column called "Unique Column" to a table called "PreviousStep". The new column will split the values from the "Column" column using a comma delimiter and then remove the duplicates.
Parsing Data from a Single Column
Suppose you have a column that contains multiple values separated by a delimiter, and you want to parse the values into separate columns. You can use the Combiner.CombineTextByDelimiter function to do this:
= Table.SplitColumn(#”PreviousStep”, “Column”, Splitter.SplitTextByDelimiter(“,”, QuoteStyle.Csv), {“Value1”, “Value2”, “Value3”})
In this example, we are using the Table.SplitColumn function to split the values from the "Column" column using a comma delimiter and create three new columns called "Value1", "Value2", and "Value3".
The Combiner.CombineTextByDelimiter function is a powerful tool for data cleaning and transformation in Power Query. By understanding the M code behind the function, users can create custom functions to automate their data cleaning processes and save time. Whether you are combining columns of text, removing duplicates, or parsing data, the Combiner.CombineTextByDelimiter function is a valuable tool for any data analyst.