asp.net高效替换大容量字符实现代码
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了asp.net高效替换大容量字符实现代码,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1494字,纯文字阅读大概需要3分钟。
内容图文
![asp.net高效替换大容量字符实现代码](/upload/InfoBanner/zyjiaocheng/382/d0f6b0cf1a1f41fca23f5cca9bab5c64.jpg)
代码如下:
str=str.replace(字符串一,字符串二)
不难发现一个问题,如果str要循环替换很多次,下一次替换时会累加上上次替换的内容,并且全遍历一次,如果字符串二很多,替换的过程就像阶梯效果,越来越大,所以速度越来越慢。要解决这个问题只能找另外的方法替换这种表达方式。
如何以更高效率代替这种操作? 思路如下:
每次替换完后,在下次替换时先排除这次替换的内容,累加本次替换的内容。
代码如下:
public Regex returnMatch(String str)//匹配正则
{
Regex r;
r = new Regex(@str,RegexOptions.IgnoreCase);
return r;
}
/// <summary>
/// 替换
/// </summary>
/// <param name="sDetail">要处理的字符</param>
/// <param name="regex">正则表达式</param>
/// <param name="replace_str">要替换的内容</param>
/// <returns>处理完的字符</returns>
public string replace(string sDetail,string regex)
{
int last_index=0;
string cut_str=sDetail;
string return_str="";
Regex r;
Match m;
r = returnMatch(regex);
for (m = r.Match(sDetail); m.Success; m = m.NextMatch())
{
int n=m.Groups[0].Length;//匹配长度
cut_str=cut_str.Substring(last_index,cut_str.Length-last_index);//去掉上次后的结果
int k=cut_str.IndexOf(m.Groups[0].ToString());//当前位置
string this_v=cut_str.Substring(k,n);//当前匹配的值
string str3=cut_str.Substring(0,k+n);//当前得到的值
//return_str+=str3.Replace(m.Groups[0].ToString(),Return_Item_Content(m.Groups[0].ToString()));
return_str+=evn(str3,m);
last_index=k+n;//记录当前匹配的位置
}
if(return_str!="")
sDetail=return_str+cut_str.Substring(last_index,cut_str.Length-last_index);
return sDetail;
}
}
内容总结
以上是互联网集市为您收集整理的asp.net高效替换大容量字符实现代码全部内容,希望文章能够帮你解决asp.net高效替换大容量字符实现代码所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。