Zuallererst würde ich sagen, dass ich hier viele Beispiele gesehen und gegoogelt habe, aber keines gefunden hat, das alle Bedingungen erfüllt Platz.
(xxx)xxxxxxx
(xxx) xxxxxxx
(xxx)xxx-xxxx
(xxx) xxx-xxxx
xxxxxxxxxx
xxx-xxx-xxxxx
Verwendung als:
const string MatchPhonePattern =
@"\(?\d{3}\)?-? *\d{3}-? *-?\d{4}";
Regex rx = new Regex(MatchPhonePattern, 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)
{
tempPhoneNumbers= match.Value.ToString(); ;
}
BEISPIELAUSGABE:
3087774825
(281)388-0388
(281)388-0300
(979) 778-0978
(281)934-2479
(281)934-2447
(979)826-3273
(979)826-3255
1334714149
(281)356-2530
(281)356-5264
(936)825-2081
(832)595-9500
(832)595-9501
281-342-2452
1334431660
\(?\d{3}\)?-? *\d{3}-? *-?\d{4}
public bool IsValidPhone(string Phone)
{
try
{
if (string.IsNullOrEmpty(Phone))
return false;
var r = new Regex(@"^\(?([0-9]{3})\)?[-.●]?([0-9]{3})[-.●]?([0-9]{4})$");
return r.IsMatch(Phone);
}
catch (Exception)
{
throw;
}
}
Um die korrekte Antwort von FlyingStreudel zu ergänzen, habe ich sie so geändert, dass sie '.' Akzeptiert. als Begrenzer, was für mich eine Voraussetzung war.
\(?\d{3}\)?[-\.]? *\d{3}[-\.]? *[-\.]?\d{4}
in Benutzung (alle Telefonnummern in einer Zeichenkette finden):
string text = "...the text to search...";
string pattern = @"\(?\d{3}\)?[-\.]? *\d{3}[-\.]? *[-\.]?\d{4}";
Regex regex = new Regex(pattern, RegexOptions.IgnoreCase);
Match match = regex.Match(text);
while (match.Success)
{
string phoneNumber = match.Groups[0].Value;
//TODO do something with the phone number
match = match.NextMatch();
}
Um alle oben genannten Vorschläge hinzuzufügen, ist hier mein RegEx, der die NANP-Standards durchsetzen wird:
((?:\(?[2-9](?(?=1)1[02-9]|(?(?=0)0[1-9]|\d{2}))\)?\D{0,3})(?:\(?[2-9](?(?=1)1[02-9]|\d{2})\)?\D{0,3})\d{4})
Dieser reguläre Ausdruck erzwingt NANP-Standardregeln wie N11 codes are used to provide three-digit dialing access to special services
und schließt sie daher mit einer bedingten Erfassung aus. Es berücksichtigt auch bis zu 3 nicht-stellige Zeichen (\D{0,3}
) zwischen den Abschnitten, da ich einige funky Daten gesehen habe.
Von den bereitgestellten Testdaten ist hier die Ausgabe:
3087774825
(281)388-0388
(281)388-0300
(979) 778-0978
(281)934-2479
(281)934-2447
(979)826-3273
(979)826-3255
(281)356-2530
(281)356-5264
(936)825-2081
(832)595-9500
(832)595-9501
281-342-2452
Beachten Sie, dass zwei Beispielwerte weggelassen wurden, weil die NANP-Standards keine gültigen Telefonnummern enthalten: Die Vorwahl beginnt mit 1
1334714149
1334431660
Die Regel, auf die ich mich beziehe, ist auf der Area Codes-Seite der National NANPA-Website zu finden, die besagt: The format of an area code is NXX, where N is any digit 2 through 9 and X is any digit 0 through 9.
Bedienen Sie sich. Verwenden Sie hierfür keine Regex. Google veröffentlicht eine großartige Bibliothek für diesen speziellen Anwendungsfall: libphonennummer . Es gibt eine Online-Demo von lib .
public static void Main()
{
var phoneUtil = PhoneNumberUtil.GetInstance();
var numberProto = phoneUtil.Parse("(979) 778-0978", "US");
var formattedPhone = phoneUtil.Format(numberProto, PhoneNumberFormat.INTERNATIONAL);
Console.WriteLine(formattedPhone);
}
Versuchen Sie, diesen Kodex zu schreiben. Möglicherweise erhalten Sie, wonach Sie suchen.
private static List<String> GetValidPhoneNumber(string input,string pattern)
{
var regex = new Regex(pattern);
var matchs = regex.Matches(input);
var validPhoneNumbers = new List<String>();
foreach(Match match in matchs)
{
if(match.Success)
{
validPhoneNumbers.Add(match.Value);
}
}
return validPhoneNumbers;
}
Oder probieren Sie diesen Code:
private static List <string>GetValidNumber(string input,string pattern)
{
var regex = new Regex(pattern);
var matches = regex.Matches(input);
return (from Match Match in matches where Match.Success select Match.Value).ToList();
}
^?\(?\d{3}?\)??-??\(?\d{3}?\)??-??\(?\d{4}?\)??-?$
Dies erlaubt: