![](/img/trans.png)
[英]Split using regex considering only first occurence of the regex pattern
[英]Using regex to split pattern
我是在正则表达式中使用模式的新手。 我已经阅读了Microsoft网站上的几个链接,以为我理解了,但是我遇到了这种情况,并且不知道为什么它没有提供我期望的结果。
我想将MyCmd拆分为字符串列表:print,a,+,b ,; 据我所知,正常分割不会使定界符保持不变。 因此,我想我已经尝试过将正则表达式与以下定义的模式一起使用:(基本上,我想将字符串拆分为列表或队列,并保留定界符;,+-* / {} [])。
string MyCmd = "print a+b;";
private string MyDelim = @"\b[\s;,\+\-\*\/%=\<\>\(\)\{\}\[\]]\w+";
myStuff = new Queue<string>(Regex.Split(MyCmd,MyDelim));
但是到目前为止,我上面的代码仍未产生预期的结果。
我的模式有什么不正确的地方?
我相信你可以用
var MyCmd = "print a+b;";
var MyDelim = @"([][\s;,+*/%=<>(){}-])";
var myStuff = Regex.Split(MyCmd,MyDelim).Where(p=> !string.IsNullOrWhiteSpace(p)).ToList();
输出: print
, a
, +
, b
;
请注意, ([][\\s;,+*/%=<>(){}-])
正则表达式用(...)
括起来,并且捕获组确保将捕获的值也添加到结果数组中。
您需要使用.Where(p=> !string.IsNullOrWhiteSpace(p))
来摆脱Regex.Split
将获得的空值。
我删除了您的正则表达式中过多的转义符,使它看起来“精简而卑鄙”。
您的正则表达式不起作用的原因是@"\\b[\\s;,\\+\\-\\*\\/%=\\<\\>\\(\\)\\{\\}\\[\\]]\\w+"
与\\b
单词边界之后的字符类中的空格和符号(要求单词字符出现在它们之前),然后匹配一个或多个单词字符。 由于没有捕获组,因此所有匹配项均从结果数组中消失。
Regex.Split
是必经之路。 如果使用Regex.Matches
,则可以这样:
string MyCmd = @"print a+b;";
string MyDelim = @"([^;,+\-*/{}\[\]\)\(\s]+|[;,+\-*/{}\[\]\)\(])";
var myStuff = Regex.Matches(MyCmd, MyDelim).Cast<Match>().ToList().ConvertAll(m => m.Groups[1].Value.ToString());
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.