这个正则表达式 - (.*).ap(.\d*)$
在在线正则表达式工具中工作正常(例如,在这里工作),但在C#中没有.
意图是对于以.ap
(以后.ap
是一些数字 - .ap1,.ap123等)结尾的字符串,我们想要捕获最后一个左边的.ap
所有内容和最后一个右边的所有内容.ap
.例如abcfile.csv.ap123
,我们想要捕获abcfile.csv
和123
.
(.*).ap(.\d*)$
在在线工具中按预期捕获这两个组,但在C#中,它捕获整个名称(在上面的示例中捕获abcfile.csv.ap123).
C#代码是 -
string renameSuffix = "ap"; Match match = Regex.Match(filename, @"(.*)\." + renameSuffix + @"(\d*)$");
match.Success为true但match.Captures.Count为1且match.Captures [0] .Value包含整个文件名(我在手表中看着这个).
这可能有什么问题?
更多例子 -
TestCashFile_10_12-25-2016_D.csv - 不应该匹配
TestCashFile_10_12-25-2016_D_A.csv.ap123 - 应匹配并捕获TestCashFile_10_12-25-2016_D_A.csv和123
TestCashFile_10_12-25-2016_D_A.csv.ap123.ds - 不应该匹配
TestCashFile_10_12-25-2016_D.csv.ap2.ap1 - 应匹配并捕获TestCashFile_10_12-25-2016_D.csv.ap2和1
Rafal.. 5
你的代码很好
只是尝试match.Groups[1]
和match.Groups[2]
在0索引中,您具有完全匹配,并且只有后续组与正则表达式组相关.
你的代码很好
只是尝试match.Groups[1]
和match.Groups[2]
在0索引中,您具有完全匹配,并且只有后续组与正则表达式组相关.