我想在< >
例如。
输入字符串:"abc" <abc@gmail.com>; "pqr" <pqr@gmail.com>;
输出字符串:abc@gmail.com;pqr@gmail.com
答案 0 :(得分:7)
string input = @"""abc"" <abc@gmail.com>; ""pqr"" <pqr@gmail.com>;";
var output = String.Join(";", Regex.Matches(input, @"\<(.+?)\>")
.Cast<Match>()
.Select(m => m.Groups[1].Value));
答案 1 :(得分:3)
经过测试
string input = "\"abc\" <abc@gmail.com>; \"pqr\" <pqr@gmail.com>;";
matchedValuesConcatenated = string.Join(";",
Regex.Matches(input, @"(?<=<)([^>]+)(?=>)")
.Cast<Match>()
.Select(m => m.Value));
(?&lt; =&lt;)是一个非捕捉的背后所以&lt;是搜索的一部分,但未包含在输出中
捕获组不是&gt;一次或多次
还可以使用非捕获组@“(?:&lt;)([^>] +)(?:&gt;)”
LB +1的答案也是正确的。直到我自己写了一个答案,我才意识到它是正确的。
答案 2 :(得分:2)
如果没有正则表达式,您可以使用:
public static string GetStringBetweenCharacters(string input, char charFrom, char charTo)
{
int posFrom = input.IndexOf(charFrom);
if (posFrom != -1) //if found char
{
int posTo = input.IndexOf(charTo, posFrom + 1);
if (posTo != -1) //if found char
{
return input.Substring(posFrom + 1, posTo - posFrom - 1);
}
}
return string.Empty;
}
然后:
GetStringBetweenCharacters("\"abc\" <abc@gmail.com>;", '<', '>')
你会得到
abc@gmail.com
答案 3 :(得分:0)
使用String.IndexOf(char, int)
method从字符串中的给定索引开始搜索<
(例如,您在>
字符处找到的最后一个索引,即在上一个结尾处电子邮件地址 - 或在查找第一个地址时0
。
只要找到另一个<
字符,就写一个重复的循环,每次找到<
字符时,都要查找下一个>
字符。使用String.Substring(int, int)
method提取您知道其开始和结束位置的电子邮件地址。
答案 4 :(得分:0)
可以使用以下正则表达式和一些linq。
var regex = new Regex(@"\<(.*?)\>");
var input= @"""abc"" <abc@gmail.com>; ""pqr"" <pqr@gmail.com>";
var matches = regex.Matches(input);
var res = string.Join(";", matches.Cast<Match>().Select(x => x.Value.Replace("<","").Replace(">","")).ToArray());
&lt;&gt;之后括号会被删除,您也可以将它集成到Regex
中。
答案 5 :(得分:-2)
string str = "\"abc\" <abc@gmail.com>; \"pqr\" <pqr@gmail.com>;";
string output = string.Empty;
while (str != string.Empty)
{
output += str.Substring(str.IndexOf("<") + 1, str.IndexOf(">") -1);
str = str.Substring(str.IndexOf(">") + 2, str.Length - str.IndexOf(">") - 2).Trim();
}