How to remove text and leave numbers in Excel or vice versa

This tutorial will teach you how to separate text from numbers in Excel by using native formulas and custom functions. You will also learn how to split text and numbers into two separate columns.

Imagine this: you receive raw data for analysis and find out that numbers are mixed with text in one column. In most situations, it will certainly be more convenient to have them in separate columns for closer examination.

In case you are working with homogeneous data, you could probably use the LEFT, RIGHT, and MID functions to extract the same number of characters from the same position. But that is an ideal scenario for laboratory tests. In real life, you are most likely to deal with dissimilar data where numbers come before text, after text or between text. The below examples provide solutions exactly for this case.

How to remove text and keep numbers in Excel cells

The solution works in Excel 365, Excel 2021, and Excel 2019

Microsoft Excel 2019 introduced a few new functions that are not available in earlier versions, and we are going to use one of such functions, namely TEXTJOIN, to strip text characters from a cell containing numbers.

The generic formula is:

TEXTJOIN("", TRUE, IFERROR(MID(cell, ROW(INDIRECT( "1:"&LEN(cell))), 1) *1, ""))

In Excel 365 and 2021, this one will also work:

TEXTJOIN("", TRUE, IFERROR(MID(cell, SEQUENCE(LEN(cell)), 1) *1, ""))

At first sight, the formulas may look a bit intimidating, but they do work :)

For example, to remove text from numbers in A2, enter one of the below formulas in B2, and then copy it down to as many cells as needed.

In Excel 365 - 2019:

=TEXTJOIN("", TRUE, IFERROR(MID(A2, ROW(INDIRECT( "1:"&LEN(A2))), 1) *1, ""))

In Excel 2019, it must be entered as an array formula with Ctrl + Shift + Enter. In dynamic array Excel, it works as a normal formula completed with the Enter key.

In Excel 365 and 2021:

=TEXTJOIN("", TRUE, IFERROR(MID(A2, SEQUENCE(LEN(A2)), 1) *1, ""))

As the result, all text characters are removed from a cell and numbers are kept:
Excel formula to remove text and leave numbers

How this formula works:

To better understand the logic, let's start investigating the formula from the inside:

You use either ROW(INDIRECT("1:"&LEN(string))) or SEQUENCE(LEN(string)) to create a sequence a numbers corresponding to the total number of characters in the source string, and then feed those sequential numbers to the MID function as the starting numbers. In B2, this part of the formula looks as follows:

MID(A2, {1;2;3;4;5;6;7;8;9;10;11;12;13;14;15}, 1)

The MID function extracts each character from A2 beginning with the very first one and returns them as an array:

{"2";"1";"0";" ";"S";"u";"n";"s";"e";"t";" ";"R";"o";"a";"d"}

This array is multiplied by 1. Numeric values survive with no change, while multiplying a non-numeric character results in a #VALUE! error:

{2;1;0;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!}

The IFERROR function handles these errors and replaces them with empty strings:

{2;1;0;"";"";"";"";"";"";"";"";"";"";"";""}

This final array is served to the TEXTJOIN function, which concatenates the non-empty values in the array (ignore_empty argument set to TRUE) using an empty string ("") for the delimiter:

TEXTJOIN("", TRUE, {2;1;0;"";"";"";"";"";"";"";"";"";"";"";""})

Tip. For Excel 2016 - 2007, a solution also exists, but the formula is far more complex. You can find it in this tutorial: How to extract numbers in Excel.

Custom function to remove text from numbers

The solution works for all Excel versions

If you are using an older version of Excel or find the above formulas too difficult to remember, nothing prevents you from creating your own function with a simpler syntax and a user-friendly name such as RemoveText. The user-defined function (UDF) can be written in two ways:

VBA code 1:

Here, we look at each character in the source string one by one and check if it's numeric or not. If a number, the character is added to the resulting string.

Function RemoveText(str As String) Dim sRes As String sRes = "" For i = 1 To Len(str) If True = IsNumeric(Mid(str, i, 1)) Then sRes = sRes & Mid(str, i, 1) End If Next i RemoveText = sRes End Function

VBA code 2:

The code creates an object to process a regular expression. Using RegExp, we remove all characters other than digits 0-9 from the source string.

Function RemoveText(str As String) As String With CreateObject("VBScript.RegExp") .Global = True .Pattern = "[^0-9]" RemoveText = .Replace(str, "") End With End Function

On small worksheets, both codes will perform equally well. On large worksheets where the function is called hundreds or thousands of times, code 2 that uses VBScript.RegExp will work faster.

The detailed steps to insert the code in your workbook can be found here: How to insert VBA code in Excel.

Whichever approach you choose, from the end-user perspective, the function to delete text and leave numbers is as simple as this:

RemoveText(string)

For instance, to remove non-numeric characters from cell A2, the formula in B2 is:

=RemoveText(A2)

Just copy it down the column, and you'll get this result:
Custom function to remove text and keep numbers in Excel

Note. Both the native formulas and custom function output a numeric string. To turn it into a number, multiply the result by 1, or add zero, or wrap the formula in the VALUE function. For example:

=RemoveText(A2) + 0

=VALUE(RemoveText(A2))

How to remove numbers from text string in Excel

The solution works in Excel 365, Excel 2021, and Excel 2019

The formulas to remove numbers from an alphanumeric string are pretty much similar to the ones discussed in the previous example.

For Excel 365 - 2019:

TEXTJOIN("", TRUE, IF(ISERR(MID(cell, ROW(INDIRECT( "1:"&LEN(cell) )), 1) *1), MID(cell, ROW(INDIRECT("1:"&LEN(cell))), 1), ""))

In Excel 2019, remember to make it an array formula by pressing the Ctrl + Shift + Enter keys together.

For Excel 365 and 2021:

TEXTJOIN("", TRUE, IF(ISERROR(MID(cell, SEQUENCE(LEN(cell 1) *1), MID(cell, SEQUENCE(LEN(cell)), 1), ""))

For example, to strip numbers from a string in A2, the formula is:

=TEXTJOIN("", TRUE, IF(ISERR(MID(A2, ROW(INDIRECT( "1:"&LEN(A2) )), 1) *1), MID(A2, ROW(INDIRECT("1:"&LEN(A2))), 1), ""))

Or

=TEXTJOIN("", TRUE, IF(ISERROR(MID(A2, SEQUENCE(LEN(A2)), 1) *1), MID(A2, SEQUENCE(LEN(A2)), 1), ""))

As the result, all numbers are removed from a cell and text characters are kept:
Excel formula to remove numbers from a text string

As shown in the screenshot above, the formula strips numeric characters from any position in a string: in the beginning, in the end, and in the middle. However, there is a caveat: if a string starts with a number followed by a space, that space is retained, which produces a problem of leading spaces (like in B2).

To get rid of extra spaces before text, wrap the formula in the TRIM function like this:

=TRIM(TEXTJOIN("", TRUE, IF(ISERROR(MID(A2, SEQUENCE(LEN(A2)), 1) *1), MID(A2, SEQUENCE(LEN(A2)), 1), "")))

Now, your results are absolutely perfect!
Remove numbers and trim spaces before text

How this formula works:

In essence, the formula works the same as explained in the previous example. The difference is that, from the final array served to the TEXTJOIN function, you need to remove numbers, not text. To have it done, we use the combination of IF and ISERROR functions.

As you remember, MID(…)+0 generates an array of numbers and #VALUE! errors representing text characters in the same positions:

{2;1;0;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!;#VALUE!}

The ISERROR function catches the errors and passes the resulting array of Boolean values to IF:

{FALSE;FALSE;FALSE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE;TRUE}

When the IF function sees TRUE (an error), it inserts the corresponding text character into the processed array with the help of another MID function. When the IF function sees FALSE (a number), it replaces it with an empty string:

{"";"";"";" ";"S";"u";"n";"s";"e";"t";" ";"R";"o";"a";"d"}

This final array is passed over to TEXTJOIN, so it concatenates the text characters and outputs the result.

Custom function to remove numbers from text

The solution works for all Excel versions

Keeping in mind that a robust formula should be kept simple, I will share the code of the user-defined function (UDF) to strip off any numeric character.

VBA code 1:

Function RemoveNumbers(str As String) Dim sRes As String sRes = "" For i = 1 To Len(str) If False = IsNumeric(Mid(str, i, 1)) Then sRes = sRes & Mid(str, i, 1) End If Next i RemoveNumbers = sRes End Function

VBA code 2:

Function RemoveNumbers(str As String) As String With CreateObject("VBScript.RegExp") .Global = True .Pattern = "[0-9]" RemoveNumbers2 = .Replace(str, "") End With End Function

As is the case with the RemoveText function, the second code is better to be used in large worksheets to optimize the performance.

Once the code is added to your workbook, you can remove all numeric characters from a cell using this custom function:

RemoveNumbers(string)

In our case, the formula in B2 is:

=RemoveNumbers(A2)

To trim leading spaces if any, nest the custom function inside TRIM like you would a native formula:

=TRIM(RemoveNumbers(A2))
Custom function to remove numbers from a string in Excel

Split numbers and text into separate columns

In situation when you want to separate text and numbers into two columns, it would be nice to have the job done with a single formula, agree? For this, we just merge the code of the RemoveText and RemoveNumbers functions into one function, named SplitTextNumbers, or simply Split, or whatever you like :)

VBA code 1:

Function SplitTextNumbers(str As String, is_remove_text As Boolean) As String Dim sNum, sText, sChar As String sCurChar = sNum = sText = "" For i = 1 To Len(str) sCurChar = Mid(str, i, 1) If True = IsNumeric(sCurChar) Then sNum = sNum & sCurChar Else sText = sText & sCurChar End If Next i If True = is_remove_text Then SplitTextNumbers = sNum Else SplitTextNumbers = sText End If End Function

VBA code 2:

Function SplitTextNumbers(str As String, is_remove_text As Boolean) As String With CreateObject("VBScript.RegExp") .Global = True If True = is_remove_text Then .Pattern = "[^0-9]" Else .Pattern = "[0-9]" End If SplitTextNumbers = .Replace(str, "") End With End Function

Our new custom function requires two arguments:

SplitTextNumbers(string, is_remove_text)

Where is_remove_text is a Boolean value indicating which characters to strip:

  • TRUE or 1 - remove text and keep numbers
  • FALSE or 0 - remove numbers and keep text

For our sample dataset, the formulas take this form:

To remove non-numeric characters:

=SplitTextNumbers(A2, TRUE)

To delete numeric characters:

=SplitTextNumbers(A2, FALSE)
Splitting numbers and text into separate columns

Tip. To avoid a potential problem of leading spaces, I recommend always wrapping the formula that removes numbers in the TRIM function:

=TRIM(SplitTextNumbers(A2, FALSE))

Special tool to remove numbers or text

For those who do not like complicating things unnecessarily, I'll show our own way of removing text or numbers in Excel.

Assuming our Ultimate Suite is added to your Excel ribbon, this is what you do:

  1. On the Ablebits Data tab, in the Text group, click Remove > Remove Characters.
    Remove characters in Excel
  2. On the add-in's pane, select the source range, choose the Remove character sets option, and pick either Text characters or Numeric characters in the drop-down list.
  3. Hit Remove and enjoy the result :)
    Remove numeric characters

Tip. If the results contain some leading spaces, the Trim Spaces tool will eliminate them in no time.

That's how to remove text or numeric characters from a string in Excel. I thank you for reading and look forward to seeing you on our blog next week!

Available downloads

Remove text or numbers in Excel - examples (.xlsm file)
Ultimate Suite - trial version (.exe file)

52 comments

  1. Hi!

    I am trying to extract only the department names, for example:
    170M - Development needs to be Development
    171M - Development WC needs to be Development WC

    I tried using this: TEXTJOIN("",TRUE,IF(ISERR(MID(text,ROW(INDIRECT("1:"&LEN(text))),1)+0),MID(text,ROW(INDIRECT("1:"&LEN(text))),1),""))
    However, I am left with dash marks and spaces..

    Is there a formula that can be created and used as a drag down formula?

    Thanks!

  2. OMG Thank you sooooooooo much! This just saved me so much time!

  3. Super helpful! TY!

  4. I need the cell to only populate the first 40 characters. I need to trim off anything longer than 40 characters.

  5. Can I know how to Split ( R SAMUEL 22SPUCH23) single cell data to split after (R SAMUEL) ( 22SPUCH23). How, It is possible in Excel

  6. Hello, can you help me on this:
    23-02-0201238549 to 201238549
    23-02-1216228450 to 216228450
    20-27-1116187482 to 116187482
    23-03-0510238759 to 510238759

    I need to remove the first 5 digit nos. Can you help me?

    thanks

  7. Hi,

    how to removeonly one space in cell?

    example
    B GCC 43 --> B GCC43

  8. how to remove space from 0P 4832

  9. Hello! I am trying to use the =TEXTJOIN("", TRUE, IFERROR(MID(A2, ROW(INDIRECT( "1:"&LEN(A2))), 1) *1, "")) function to extract a the number from a column such as:

    0.5 ML
    1 EA
    0.2 ML
    1 ML

    This works great when the number is not a decimal but with the 0.5 for example it translates into 05. Anyway to use this function while preserving the decimal?

    • Hi! To extract a number along with the decimal separator from the text, try this formula:

      =TEXTJOIN("",TRUE, IFERROR(MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)*1, IF(MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)=".",".","")))

  10. Sir/madam,
    When analyzing regression I get F value, significant value and p value as #NUM!
    Kindly tell how to clear this

    Thanking you

    Regards
    C Jayasundari

  11. ACS98332
    CB10311A
    CBS10351A

    how can I remove the text from the above codes

  12. QAR 800.00

    hi, anyone can you help me how to remove this "QAR" in the currency.

  13. 0:59972400
    1:67140000
    2:24948000
    3:19728000
    Can I know how to remove the "0: & 1: & 2:" from the above numbers

    • 0:599724001324
      1:67140000
      2:2494
      3:19728000234
      if we have a random number how?
      Can I know how to remove the "0: & 1: & 2:" from the above numbers

        • Thank you Alex

        • In B1:
          =TEXTJOIN("",TRUE,SUBSTITUTE(SUBSTITUTE(A1,{0,1,2,3,4,5,6,7,8,9}&":",""),A1,""))

  14. That was very helpful, thank you.

  15. Dear Alexander Trifuntov cordial greetings

    I am working with a series of codes as follows

    100001-PTR012
    100001-PV012

    I need to extract the non-numeric characters located after the hyphen (-), for which I have used the following formula:

    =MID(A1,FIND("-",A1)+1,FIND("0",A1,FIND("-",A1))-FIND("-",A1)-1)

    So far everything works

    The problem arises when in the code, after the hyphen, the numeric characters begin with a non-zero (0) character, for example:

    100001-PTR912
    100001-PV512
    100001-PVEW71204

    What would be the best way to obtain only the non-numeric characters located after the hyphen, when they are preceded by non-zero numbers?

    I appreciate your valuable collaboration.

    • Hello!
      If I got you right, the formula below will help you with your task:

      =LEFT(MID(A1,SEARCH("-",A1)+1,50), MIN(IFERROR(SEARCH({1,2,3,4,5,6,7,8,9,0}, MID(A1,SEARCH("-",A1)+1,50),1),10000))-1)

      Use the LEFT function to start your search at the character following the "-".

      • Dear thank you very much for your help. It works correctly, a big hug!

  16. Hi, I'm using the RemoveText custom function but it doesn't preserve decimals. For example, 950.43 becomes 95043. Is there a way to save the decimals?

  17. Thanks! That worked perfectly!

  18. Hello,

    It's the perfect solution. How to make an empty cell for the blank cell? Since we drag the formula down, the empty cell grabs some wired string and special character.

    Thank you!

    • Hi Evan,

      Nest your formula in the IF function like this:

      =IF(A2="", "", your_formula)

      Where A2 is the cell with the original data.

  19. Hi Svetlana,
    This is such a cool example; thank you for providing it. In my data I am trying to pull out numeric value from my text which is listed for example as 70 MPH. There could be other numeric values after the MPH but I dont want those. Can this formula be adjuster to only pull the numberic value before MPH? Thanks!

  20. Hi Svetlana,

    what is the software you use to highlight your images in all your articles?

    Kind regards

      • Thank you
        Regards

Post a comment



Thank you for your comment!
When posting a question, please be very clear and concise. This will help us provide a quick and relevant solution to
your query. We cannot guarantee that we will answer every question, but we'll do our best :)