在C#中,處理正則表達式中的嵌套結構稍微復雜一些,因為C#的正則表達式引擎(System.Text.RegularExpressions.Regex)不支持遞歸匹配。但是,你可以使用一些技巧來處理嵌套結構。
一種方法是使用非捕獲組和條件表達式。例如,假設你有以下嵌套結構:
<div>
<p>Text1</p>
<div>
<p>Text2</p>
</div>
</div>
你可以使用以下正則表達式來匹配這個結構:
using System;
using System.Text.RegularExpressions;
class Program
{
static void Main()
{
string input = "<div><p>Text1</p<div><p>Text2</p></div></div>";
string pattern = @"<(?<tag>[a-zA-Z]+)(?<content>(?<inner>.*?)</?(?<tag>\1)>(?<content2>(?<inner2>.*?)</?(?<tag>\1)>)*)>";
Match match = Regex.Match(input, pattern);
if (match.Success)
{
Console.WriteLine("Tag: " + match.Groups["tag"].Value);
Console.WriteLine("Content: " + match.Groups["content"].Value);
Console.WriteLine("Inner content: " + match.Groups["inner"].Value);
Console.WriteLine("Content 2: " + match.Groups["content2"].Value);
}
}
}
這個正則表達式使用了非捕獲組(?<tag>[a-zA-Z]+)
來匹配標簽名,捕獲組(?<content>(?<inner>.*?)</?(?<tag>\1)>(?<content2>(?<inner2>.*?)</?(?<tag>\1)>)*)
來匹配嵌套的內容。注意,這個正則表達式可能無法處理所有可能的HTML嵌套結構,但它可以處理你提供的示例。
如果你需要處理更復雜的嵌套結構,可能需要使用其他方法,例如使用HTML解析器(如HtmlAgilityPack)來解析HTML文檔并提取所需的信息。