Thunder
Thunder

Reputation: 10986

extract all email address from a text using c#

Is there a way to extract all email addresses from a plain text using C# .

For example

my email address is [email protected] and his email is [email protected]

should return

[email protected], [email protected]

I have tried the following but it matches perfect emails only.

 public const string MatchEmailPattern =
            @"^(([\w-]+\.)+[\w-]+|([a-zA-Z]{1}|[\w-]{2,}))@"
            + @"((([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\.([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\."
              + @"([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\.([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])){1}|"
            + @"([a-zA-Z]+[\w-]+\.)+[a-zA-Z]{2,4})$";


        public static bool IsEmail(string email)
        {
            if (email != null) return Regex.IsMatch(email, MatchEmailPattern);
            else return false;
        }

Upvotes: 54

Views: 62031

Answers (5)

Thunder
Thunder

Reputation: 10986

Following works

public static void emas(string text)
{
    const string MatchEmailPattern =
      @"(([\w-]+\.)+[\w-]+|([a-zA-Z]{1}|[\w-]{2,}))@"
      + @"((([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\.([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\."
      + @"([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\.([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])){1}|"
      + @"([a-zA-Z]+[\w-]+\.)+[a-zA-Z]{2,4})";

     Regex rx = new Regex(
       MatchEmailPattern,
       RegexOptions.Compiled | RegexOptions.IgnoreCase);

     // Find matches.
      MatchCollection matches = rx.Matches(text);

     // Report the number of matches found.
     int noOfMatches = matches.Count;

     // Report on each match.
     foreach (Match match in matches)
     {
       Console.WriteLine(match.Value.ToString());
     }
}

Upvotes: 31

Meysam Javadi
Meysam Javadi

Reputation: 1404

check this snippet

using System.IO;
using System.Text.RegularExpressions;
using System.Text;

class MailExtracter
{

    public static void ExtractEmails(string inFilePath, string outFilePath)
    {
        string data = File.ReadAllText(inFilePath); //read File 
        //instantiate with this pattern 
        Regex emailRegex = new Regex(@"\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*",
            RegexOptions.IgnoreCase);
        //find items that matches with our pattern
        MatchCollection emailMatches = emailRegex.Matches(data);

        StringBuilder sb = new StringBuilder();

        foreach (Match emailMatch in emailMatches)
        {
            sb.AppendLine(emailMatch.Value);
        }
        //store to file
        File.WriteAllText(outFilePath, sb.ToString());
    }
}

Upvotes: 85

Oded
Oded

Reputation: 498904

If you don't want it to match perfect email addresses, don't use a regular expression that matches perfect email addresses.

The regular expression you are using will match on the start of the line (^) and the end of the line ($), so if you remove those it will not filter with them.

Upvotes: 0

user26901
user26901

Reputation:

give this a try http://www.regular-expressions.info/email.html

Upvotes: 3

David Morton
David Morton

Reputation: 16505

Just remove the "^" from the beginning and the "$" from the end of your filter string.

Upvotes: 6

Related Questions