Power Automate: Remove Characters From A String

Power Automate: Remove Characters From A String

A Power Automate flow can unexpectedly fail to due invalid characters in a file name. To solve this problem we can obtain the file name and use Power Automate to remove characters from a string. I will show you two approaches to do this: defining a list of non valid characters and removing them from a filename and creating a list of valid characters and keeping them in the file name.

Table of Contents
• Introduction: The File Name With Special Characters

#1 Remove Invalid Characters Method
• Remove Characters From A String In Power AutomateFlow Expressions To Remove Characters From A StringRun The Flow To Remove Characters From A StringUnderstanding How The Flow To Remove Characters Works

#2 Keep Only Valid Characters Method
• Keep Only Valid Characters In A Text StringFlow Expressions To Keep Only Valid Characters In A Text StringRun The Flow To Keep Only Valid Characters In A StringExplaining The Flow To Keep Only Valid Characters In A String




Introduction: The File Name With Special Characters

A member of the Technology department uses a Power Automate flow to ensure filenames have only valid characters.



The flow removes any special characters from the filename.




#1 Remove Invalid Characters Method


Remove Characters From A String In Power Automate

Open Power Automate and create a new instant flow to remove the non valid characters from a text string. Add all of the actions shown the image below to the flow. It will take the following steps:

  • Compose a string of the non valid characters to be removed from the text string
  • Pass in the string value to be cleaned
  • Check each character in the string value one-by-one
  • Filter and remove any non-valid characters




Flow Expressions To Remove Characters From A String

Copy and paste these text values and flow expressions into the appropriate actions to quickly build the flow.

Compose: Non Valid Characters – Inputs field

~`!@#$%^&*()+|{}[]<>/\?;:.,


Compose: Text String To Validate – Inputs field

data$batch!-2024.03.02


Select: Array Of Text String Chars To Validate – From field

range(0,length(outputs('Compose:_Text_String_To_Validate')))


Select: Array Of Text String Chars To Validate – Map field – Index value

indexOf(outputs('Compose:_Non_Valid_Characters'), substring(outputs('Compose:_Text_String_To_Validate'),item(),1))


Filter array – Index Equals -1 (choose a value field)

item()['Index']


Select: Array Of Text String Chars To Validate – Map field – Char value

substring(outputs('Compose:_Text_String_To_Validate'),item(),1)


Compose: Valid Text String – Inputs field

join(body('Select:_Array_Of_Valid_Characters'), '')




Run The Flow To Remove Characters From A String

After the flow is created give it a test to run ensure it works as expected. The text string in our example data$batch!-2024.03.02 is changed to databatch-20240302.




Understanding How The Flow To Remove Characters Works

The flow successfully removes non valid characters from a string but how does it work? The flow action Select: Array Of Text String Chars To Validate builds an array of characters in the text string paired with an index number. An index of -1 means the character was not found in the string of non valid characters. Indexes with a value not equals to -1 have a non valid character.



Then we filter the array to show only valid characters in the action Filter array: Index Equals -1.



The filtered array is transformed into a simple array of characters in Select: Array Of Valid Characters which are re-joined into a text string in the action Compose: Valid Text String.




#2 Keep Only Valid Characters Method


Keep Only Valid Characters In A Text String

Compiling a list all of the non valid characters which can be found in a string is difficult. It is simpler to approach the problem by defining a list of valid characters instead. We will create another flow to illustrate this method.

Open Power Automate and create a new instant flow to remove the non valid characters from a text string. Add all of the actions shown the image below to the flow




Flow Expressions To Keep Only Valid Characters In A Text String

Copy and paste these text values and flow expressions into the appropriate actions to quickly build the flow.


Compose: Valid Characters – Inputs field

ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_-


Compose: Text String To Validate – Inputs field

data$batch!-2024.03.02


Select: Array Of Text String Chars To Validate – From field

range(0,length(outputs('Compose:_Text_String_To_Validate')))


Select: Array Of Text String Chars To Validate – Map field – Index value

indexOf(outputs('Compose:_Valid_Characters'), substring(outputs('Compose:_Text_String_To_Validate'),item(),1))


Filter array: Index Does Not Equal -1 (choose a value field)

item()['Index']


Select: Array Of Text String Chars To Validate – Map field – Char value

substring(outputs('Compose:_Text_String_To_Validate'),item(),1)



Compose: Valid Text String – Inputs field

join(body('Select:_Array_Of_Valid_Characters'), '')




Run The Flow To Keep Only Valid Characters In A String

Now that the flow is complete perform a test to run ensure it works properly. Once again, the text string in our example data$batch!-2024.03.02 is changed to databatch-20240302.




Explaining The Flow To Keep Only Valid Characters In A String

Just as before, the flow action Select: Array Of Text String Chars To Validate builds an array of characters in the text string paired with an index number. An index of -1 means the character was not found in the string of non valid characters. Indexes with a value not equals to -1 have a non valid character.



But this time we filter the array differently to show only characters that do not equal -1 in the action Filter array: Index Does Not Equal -1.



Finally we, reconstruct the simple array of characters in Select: Array Of Valid Characters are once again joined into a text string in the action Compose: Valid Text String.




Questions?

If you have any questions or feedback about Power Automate: Remove Characters From A String please leave a message in the comments section below. You can post using your email address and are not required to create an account to join the discussion.

Matthew Devaney

Subscribe
Notify of
guest

21 Comments
Oldest
Newest
Inline Feedbacks
View all comments
michal
michal
9 months ago

Could You provide expressions inside Filter and 2nd Select actions? I am getting error there 🙂

michal
michal
9 months ago

In last Select after copy this expression comes error :
The value of second parameter is of type ‘Object’ but the function ‘substring’ expects a integer or a decimal number.

michal
michal
9 months ago
Reply to  michal

I am following #1 Remove Invalid Characters Method scenarioCould you paste “Select: array of valid Characters” action expressions? 🙂

michal
michal
9 months ago
Reply to  michal

ok – my mistake.. sorry for messages.
item()[‘Char’] works good

Keith
Keith
9 months ago
Reply to  michal

In the “Select: Array of valid characters” I have item()[‘Char’] and I get this {“N”:””} I only want the N. When I try to do a substring I get an error about ‘substring’ out of range.

Last edited 9 months ago by Keith
Keith
Keith
9 months ago

I am using your code in my own flow and that is the first letter brought back from a contract number. I figured it out though I had to modify the text output for only the letter and not all the other characters like the { and the ” marks. The information was very helpful. Thank you

laurel
laurel
8 months ago
Reply to  michal

how did you resolve this? having the same issue! THANKS

Hasham
Hasham
9 months ago

Hi Matthew,

When i used item()[‘Char’] in Select: Array of Valid Characters
Output shows:
{
“d” : “”
}.
It should look like your output
“d”,
“a,”

Last edited 9 months ago by Hasham
Michael
Michael
9 months ago

In the “Select: Array of Valid Characters” you never show/say what to set for the Map field.

What should be in that? It shows the Char output from somewhere but I don’t have that as a selectable option, and I’ve confirmed everything else exactly matches what you show in this.

Aaron Christopher Knox
8 months ago
Reply to  Michael

The missing code: In the Map field for Select:Array of Valid Characters the code is:

item()['Char']

You will want to switch to Text mode before you add the code to Map. Then paste in item()[‘Char’]. The screenshot is misleading because when you add this it will be the red ‘fx expression’ format ‘item()’ but once you save it and come bac, it will revert to the screenshot here and change to the purple ‘Char’.

Great job, Matt, as per usual!

Sunil
Sunil
8 months ago

I am using the first approach but I am getting an error on select action after filtering the array.

substring(outputs('Compose:_Text_String_To_Validate'),item(),1)

The flow says that the second value should be an integer instead of an object.

Aaron Christopher Knox
6 months ago

Thanks, Matt, for the awesome Power Platform blog site. Your hard work helps countless IT pros around the world!

I’d like to add to the conversation that you can also use the Replace() function to replace characters in a string. Replace() can be nested, so you replace the first character from the string source, then add extra nested replace() functions for the other characters. It might seem like a ton of ugly code, but a single line of code to replace several actions helps keep your flow nice and tidy.

This example removes characters from the variable varString1 by replacing each character with a blank value, ”:

replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(variables('varString1'),'~',''),'`',''),'!',''),'@',''),'#',''),'$',''),'%',''),'^',''),'&',''),'*',''),'(',''),')',''),'+',''),'|',''),'{',''),'}',''),'[',''),']',''),'<',''),'>',''),'/',''),'\',''),'?',''),';',''),':',''),'.',''),',','')

Cheers!
Aaron

Helping
Helping
5 months ago

Caitlin,
He pasted the value one the page but at a confusing place (filter parameter is between two “Select: Array Of Text String Chars To Validate – Map field – XXX value”).

Check the code for:

Select: Array Of Text String Chars To Validate – Map field – Index value

and lower down

Select: Array Of Text String Chars To Validate – Map field – Char value

Caitlin
Caitlin
5 months ago

When I try to run this, it throws an error that 2 parameters are needed for the indexOf step in the select step. any attempt to fix it causes all of the characters to have an index of -1, like its looking at the whole string of valid characters instead of individually. How did you get indexOf to run with only one string parameter? any help is appreciated. Thanks! :):)

Neil
Neil
3 months ago

Hi currently using #2 Keep Only Valid Characters Method
When i try to use the following expression in the ‘Select: Array Of Text String Chars To Validate’ step, I get the message ‘The expression is invalid’:

Select: Array Of Text String Chars To Validate

Select: Array Of Text String Chars To Validate – Map field – Index value

All the labelling is correct on the steps so not sure why the expressions aren’t being accepted for this step. Can you please provide some advice 🙂 ?

Mel
Mel
1 month ago
Reply to  Neil

I have also run into this error and spent over an hour trying to figure out what was going on. I checked that the functions were properly closed, that all the quotes were single quotes, and that I didn’t enter the names of the functions wrong.

hvandesa
hvandesa
1 month ago

I couldn’t get the Filter array: Index Does Not Equal -1 (choose a value field) to work. I had to use Greater or Equal 0 instead. (“where”: “@greaterOrEquals(item()[‘Index’],0)”)