Extract An E-mail Address From A Cell Containing Other Text
May 19, 2021 - by Bill Jelen
data:image/s3,"s3://crabby-images/350a5/350a58c7543c7b43d6d3fb353b8cf810bce3d7a3" alt="Extract An E-mail Address From A Cell Containing Other Text Extract An E-mail Address From A Cell Containing Other Text"
Challenge: You have cells that contain e-mail addresses as well as other text. You need to extract just the e-mail address from a cell.
Solution: There are three solutions to this problem: Use a macro, use a user-defined function, or use a very large formula.
Macro Solution
The macro solution makes use of the SPLIT function in VBA. Let’s say that a cell contains the text Write to lora@mrexcel.com to book a seminar. If you pass this text to the SPLIT function and indicate that the text should be split at every space character, VBA will return an array, with each word at a new position of the array. Figure 124 shows the value of x after you use SPLIT.
data:image/s3,"s3://crabby-images/586dd/586dd490c846acc319d778f9ed1ac20dfae2b8b5" alt="Figure 124. The SPLIT function returns a 0-based array, with each word broken out."
The macro then simply loops through each position in the x array, looking for a word that matches the pattern *@*.*. (Rather than test for equality, the LIKE operator looks for a word that matches a pattern.)
When a match is found, the macro writes the e-mail address to the right of the original cell.
With the following macro, you select all the cells that contain text e-mail addresses somewhere within the cell:
data:image/s3,"s3://crabby-images/a2f37/a2f37b53c4495670cb54fa7031ead47b4c88d735" alt="e9781615474011_i0227.jpg"
When you run the macro, the e-mail address portion of the cell is written to the right of the original values.
User-Defined Function Solution
You can adapt the macro above into a user-defined function that accepts one cell value as an argument and returns the e-mail portion of the text:
data:image/s3,"s3://crabby-images/0a95b/0a95b333ca50b78f8006ffde759e180b4b9f9fae" alt="e9781615474011_i0228.jpg"
Formula Solution
While the following formula would take some time to build, it is clever and remarkably simple in its operation:
data:image/s3,"s3://crabby-images/d8926/d8926deea5219ec55a050bde12a2e0d4d60f972d" alt="e9781615474011_i0229.jpg"
The formula initially uses the SUBSTITUTE function to replace every occurrence of a space with 20 spaces. This serves to separate every word in the text by many spaces:
Original Text: Tell bill@mrexcel.com hello
New Text: | Tell | bill@mrexcel.com |
hello |
The FIND function locates the @ sign in the new text. The MID function starts 20 characters before the @ and grabs text for 40 characters. I used 40 characters because that should be long enough to handle any possible e-mail address. In fact, it would fail if you had john.jacob.jingleheimer.schmidt@gmail. com in your database. However, for a normal-sized e-mail address, you end up with something like:
data:image/s3,"s3://crabby-images/61158/61158a33538bd13cd6488ea1b034671c4c00b213" alt="e9781615474011_i0231.jpg"
Finally, the TRIM function removes all leading and trailing spaces, so you end up with:
data:image/s3,"s3://crabby-images/58a2a/58a2a599fa76792ddc673eccd6ca52795bcc3183" alt="e9781615474011_i0232.jpg"
Figure 125 shows the result of the formula.
data:image/s3,"s3://crabby-images/44739/44739d91f41fa79ca262e9d3b8dc3878a87be66f" alt="Figure 125. The formula isolates the e-mail portion of the text."
Summary: You can use three different methods to extract the e-mail address from a cell that contains an e-mail address as well as other text
Source: Extract from String on the MrExcel Message Board.
Title Photo: Solen Feyissa on Unsplash
This article is an excerpt from Excel Gurus Gone Wild.