我有一些字符串
bla bla bla bla <I NEED THIS TEXT>
获取文本的最佳和最快方法是什么<>
?
int start = s.IndexOf("<") + 1;
int end = s.IndexOf(">",start);
string text = s.Substring(start,end - start);
var s = "bla bla bla bla <I NEED THIS TEXT> ";
Console.WriteLine(s.Substring(s.IndexOf('<') + 1, s.IndexOf('>') - s.IndexOf('<') - 1));
Regex.Match(input, "<(.*)>").Groups[1].Value
var input = "bla bla bla bla <I NEED THIS TEXT> ";
var match = Regex.Match(input, @".*?<(?<MyGroup>.*?)>");
if (match.Success)
var text = match.Groups["MyGroup"].Value;
会有筑巢吗?上面的两个答案将给出不同的结果:
static void Main()
{
string s = "hello<I NEED <I NEED THIS TEXT> THIS TEXT>goodbye";
string r = Regex.Match(s, "<(.*)>").Groups[1].Value;
int start = s.IndexOf("<") + 1;
int end = s.IndexOf(">", start);
string t = s.Substring(start, end - start);
Console.WriteLine(r);
Console.WriteLine(t);
Console.ReadKey();
}
没有正则表达式和各种检查:
var data = "bla bla bla bla <I NEED THIS TEXT>";
int start = 0, end = 0;
if ((start = data .IndexOf("<")) > 0 &&
(end = data .IndexOf(">", start)) > 0)
{
var result = data .Substring(start + 1, end - start - 1);
}
使用 string.SubString 和 IndexOf mwthods 只会工作是“<”和“>”是您想要的文本的开始和结束。如果在实际文本开始之前恰好包含这些字符,那么您将不会得到正确的字符串。
最好的办法是使用正则表达式。
var input = "bla bla bla bla <I NEED THIS TEXT>";
Match match = Regex.Match(input, @"<([^>]*)>");
if (match.Success)
{
// Do some with match.Groups[1].Value;
}