[英]Regex get last occurrence of the pattern
我有一个字符串,我需要选择模式的最后一次出现。 字符串是:
[[[1302638400000.0,0],[1302724800000.0,610.64999999999998],[1302811200000.0,2266.6500000000001],[1303156800000.0,4916.9300000000003],[1303329600000.0,6107.3199999999997],[1303934400000.0,9114.6700000000001] ,, [[130263840.00.000000000] ],[1302811200000.0、20000.0],[1303156800000.0、20000.0],[1303329600000.0、20000.0],[1303934400000.0、20000.0],[[1302638400000.0、20000.0],[1302724800000.0、20610.650000000001],[1302811200000.0、22266.650000000001],[1303156800000.0、24916 ],[1303329600000.0、26107.32],[1303934400000.0、29114.669999999998],[1304452800000.0、30078.23], [[1302718580000.0、0.0],[1302772440000.0、3.0532500000000073],[1303107093000.0、11.333250000000007],[1303107102000.00.0、21.753250000000229008 ],[1303352311000.0、26.8766],[1303815010000.0、30.536599999999996],[1303815028000.0、27.703349999999993]]];
我使用的模式是:
\s\[\[(.*?)\]\]
不幸的是,它仅选择第一个事件。 高亮显示的文本是所需的结果。 到底有多少个方括号都没有关系,只需要最后一个数组集即可。
更新:如果可以帮助您,则编码使用c#
使用RightToLeft
选项:
Regex.Match(s, @"\[\[(.*?)\]\]", RegexOptions.RightToLeft)
该选项是.NET regex风格所独有的,并且完全满足您的要求:从输入的末尾而不是开头搜索。 特别值得注意的是,非贪婪?
修饰符按您的预期工作; 如果不使用它,您将获得全部输入,但是得到:
[[1302718580000.0, 0.0], [1302772440000.0, 3.0532500000000073], [1303107093000.0, 11.333250000000007], [1303107102000.0, 21.753250000000008], [1303352295000.0, 24.584650000000003], [1303352311000.0, 26.8766], [1303815010000.0, 30.536599999999996], [1303815028000.0, 27.703349999999993]]]
尝试将$像这样\\s\\[\\[(.*?)\\]\\]\\]\\;$
添加到您的模式中\\s\\[\\[(.*?)\\]\\]\\]\\;$
然后让我知道它是否有效。
目前,我手头没有重击,所以无法检查,但应该可以解决。
编辑:正确的版本\\S+\\s?+(?!((.*\\[\\[)))
转换为:
\S : all alfanumeric
\s? : all 1 space occurences
?! : not
.* : everything
\[\[ : until the last pattern of [[ (excluded)
顺便说一句很棒的工具rubular,让我想更深入地研究ruby和正则表达式:D
应该有一个全局标志或一种方法来返回您语言中的所有匹配项。 使用它并进行最后一场比赛。
在C#中, Matches()
返回包含所有找到的匹配项的MatchCollection
。 因此,您可以这样做:
string source = "[[[1302638400000.0, 0], [1302724800000.0, 610.64999999999998], [1302811200000.0, 2266.6500000000001], [1303156800000.0, 4916.9300000000003], [1303329600000.0, 6107.3199999999997], [1303934400000.0, 9114.6700000000001]], [[1302638400000.0, 20000.0], [1302724800000.0, 20000.0], [1302811200000.0, 20000.0], [1303156800000.0, 20000.0], [1303329600000.0, 20000.0], [1303934400000.0, 20000.0]], [[1302638400000.0, 20000.0], [1302724800000.0, 20610.650000000001], [1302811200000.0, 22266.650000000001], [1303156800000.0, 24916.93], [1303329600000.0, 26107.32], [1303934400000.0, 29114.669999999998], [1304452800000.0, 30078.23]], [[1302718580000.0, 0.0], [1302772440000.0, 3.0532500000000073], [1303107093000.0, 11.333250000000007], [1303107102000.0, 21.753250000000008], [1303352295000.0, 24.584650000000003], [1303352311000.0, 26.8766], [1303815010000.0, 30.536599999999996], [1303815028000.0, 27.703349999999993]]];";
Regex r = new Regex(@"\s\[\[(.*?)\]\]");
MatchCollection result = r.Matches(source);
if (result.Count > 0) {
Console.WriteLine(result[result.Count - 1]);
} else {
Console.WriteLine("No match found!");
}
Console.ReadLine();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.