Linq
Если вы используете .Net 3.5 или выше, например 4.7, linq можно использовать для удаления дубликатов совпадения.
string data = "abc match match abc";
Console.WriteLine(string.Join(", ",
Regex.Matches(data, @"([^\s]+)")
.OfType<Match>()
.Select (m => m.Groups[0].Value)
.Distinct()
));
// Outputs abc, match
.Net 2или Нет Linq
Поместите его в таблицу, затем извлеките строки:
string data = "abc match match abc";
MatchCollection mc = Regex.Matches(data, @"[^\s]+");
Hashtable hash = new Hashtable();
foreach (Match mt in mc)
{
string foundMatch = mt.ToString();
if (hash.Contains(foundMatch) == false)
hash.Add(foundMatch, string.Empty);
}
// Outputs abc and match.
foreach (DictionaryEntry element in hash)
Console.WriteLine (element.Key);