在 Java 中,我可以使用 Regex 简单地提取部分代码或文本,但在 C# 中,我不确定如何做到这一点。 例如:
Pattern p = Pattern.compile("(.*?)b(.*?)d(.*?)", Pattern.DOTALL|Pattern.MULTILINE);
Matcher matcher = p.matcher("abcde");
System.out.println(matcher.group(1)); //c
我发现了很多关于 C# 中正则表达式的教程,但我发现没有办法做这样简单的事情。但它必须适用于各种类型和数量的文本、数字、符号等,以便我可以使用它来提取部分 HTML 代码。
最佳答案
首先。您的 java 代码不能按原样工作。
正确的代码(已测试):
Pattern p = Pattern.compile("(.*?)b(.*?)d(.*?)", Pattern.DOTALL|Pattern.MULTILINE);
Matcher matcher = p.matcher("abcde");
if (matcher.find()) // Without this test: [Exception in thread "main" java.lang.IllegalStateException: No match found]
System.out.println(matcher.group(2)); //c <--2 instead of 1
C# 中的等效项(已测试):
Regex r = new Regex("(.*?)b(.*?)d(.*?)", RegexOptions.Singleline | RegexOptions.Multiline);
Match matcher = r.Match("abcde");
Console.WriteLine(matcher.Groups[2]); //c
关于c# - 在 C# 中使用正则表达式提取文本部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11621614/