Power Query: Space for a CamelCase
25 November 2020
Welcome to our Power Query blog. This week, I look at how to automate inserting spaces into CamelCase headings.
I have some tent data:
data:image/s3,"s3://crabby-images/013a2/013a2ce61f2eed349b76088f7e5599948f9e2869" alt=""
My headings are in CamelCase, i.e. each word begins with a capital letter, but there is no space between the words. I want to change all my headings to separated words.
I extract my data to Power Query by using ‘From Table’ in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/8154a/8154a1420035805572d34fe2468ef370af2600f4" alt=""
I accept the usual defaults.
data:image/s3,"s3://crabby-images/29031/290315c2e05d02b586b6347b7e5dd88ab8e7a16a" alt=""
I want to investigate how Power Query would do this; I am going to demote my headings and manipulate my data.
data:image/s3,"s3://crabby-images/1b6a8/1b6a8ffdeaeea93e4c0535516a4b00b4ad74bf77" alt=""
On the Transform tab, I can ‘Use Headers as First Row’ in the dropdown from ‘Use First Row as Headers’.
data:image/s3,"s3://crabby-images/4c362/4c362a9bdffa557abb648c10bb28e8956827dff4" alt=""
I can now look at how I could divide up my data. I can use the ‘Split Column’ options on the Transform tab.
data:image/s3,"s3://crabby-images/7683c/7683cccfccf2f2b1be969bf5382ba9806114da83" alt=""
I have the option to split ‘By Lowercase to Uppercase’, which is similar to the effect I want to achieve. I try this.
data:image/s3,"s3://crabby-images/561bf/561bf22770b3d1bd426322bf62332bc9567f019e" alt=""
This has separated my data into individual words, and now I can recombine the columns.
data:image/s3,"s3://crabby-images/ca338/ca338830e57d77ed4f3f8d298db17ded43e6900c" alt=""
I select my new columns and choose ‘Merge Columns’.
data:image/s3,"s3://crabby-images/a6c68/a6c68f9ba92ec9ca73fa7054387aa4689700609b" alt=""
I choose to use a space as the separator.
data:image/s3,"s3://crabby-images/736c0/736c0f5c82e0a316380bc5d8ebccde5ca4acafc2" alt=""
I now have the two core parts of the code I will need. I need to split the text by change of case, and then combine my text with a delimiter. In Power Query, these functions are Splitter.SplitTextByCharacterTransition() and Text.Combine().
Splitter.SplitTextByCharacterTransition(before as anynonnull, after as anynonnull) as function
This returns a function that splits text into a list of text, according to a transition from one kind of character to another. The before and after parameters can either be a list of characters, or a function that takes a character and returns true / false.
In the step, the code is:
Splitter.SplitTextByCharacterTransition({"a".."z"}, {"A".."Z"})
Text.Combine(texts as list, optional separator as nullable text) as text
returns the result of combining the list of text values, texts, into a single text value. An optional separator used in the final combined text may be specified, separator.
I don’t have to demote my headings to make these changes thanks to another Power Query M function Table.TransformColumnNames():
Table.TransformColumnNames(table as table, nameGenerator as function, optional options as nullable record) as table
This transforms column names by using the given nameGenerator function.
I can combine these M functions to get my result.
data:image/s3,"s3://crabby-images/ee22f/ee22f3e9b30441ecd0b20530fceedd4710ccc178" alt=""
When I enter my new step I can see the results:
data:image/s3,"s3://crabby-images/9a7b0/9a7b0f68c84d784d7060abd34e884195607288ef" alt=""
The M code I have used is:
= Table.TransformColumnNames(#"Changed Type", each Text.Combine(Splitter.SplitTextByPositions(Text.PositionOfAny(_, {"A".."Z"},2)) (_), " "))
This will convert CamelCase to separate words in any number of column headings.
Come back next time for more ways to use Power Query!