日期:2014-05-18  浏览次数:20836 次

正则表达式问题:匹配字符串<sup>与</sup>之外的逗号
源HTML字符串:
HTML code
abc<sup>1,2</sup>,defdfe<sup>3,4</sup>,ghijdfd,fdfdk

需要把逗号替换为分号,但是<sup>和</sup>之间的逗号需要保留。
替换结果为:
HTML code
abc<sup>1,2</sup>;defdfe<sup>3,4</sup>;ghijdfd;fdfdk




------解决方案--------------------
System.Text.RegularExpressions.Regex r = new System.Text.RegularExpressions.Regex("(?<!<sup[^>]*>[^<]*),(?![^<]*</sup>)");
string result = r.Replace("abc<sup>1,2</sup>,defdfe<sup>3,4</sup>,ghijdfd,fdfdk", ";");
试试
------解决方案--------------------
这种需求比较适合用委托来处理

C# code
Regex reg = new Regex(@"(?i)(?<=^|</sup>).+?(?=<sup>|$)");
string result = reg.Replace(yourStr, delegate(Match m) { return m.Value.Replace(",", ";"); });

------解决方案--------------------
C# code

 var testSource = "abc,<sup>1,2,</sup>,defdfe<sup>3,4</sup>,ghijdfd,fdfdk<sup><span>,ss</span></sup>456464,";
               var pattern = @",(?!(?:(?!</?sup\b).)*</sup\s*>)";

               var resultStr = Regex.Replace(testSource,pattern,";",RegexOptions.IgnoreCase);
               Console.WriteLine(resultStr);