asp.net高效替換大容量字符實(shí)現(xiàn)代碼
更新時(shí)間:2008年08月30日 08:32:31 作者:
每次替換完后,在下次替換時(shí)先排除這次替換的內(nèi)容,累加本次替換的內(nèi)容。
一般進(jìn)行替換操作都這樣:
str=str.replace(字符串一,字符串二)
不難發(fā)現(xiàn)一個(gè)問題,如果str要循環(huán)替換很多次,下一次替換時(shí)會(huì)累加上上次替換的內(nèi)容,并且全遍歷一次,如果字符串二很多,替換的過程就像階梯效果,越來越大,所以速度越來越慢。要解決這個(gè)問題只能找另外的方法替換這種表達(dá)方式。
如何以更高效率代替這種操作? 思路如下:
每次替換完后,在下次替換時(shí)先排除這次替換的內(nèi)容,累加本次替換的內(nèi)容。
public Regex returnMatch(String str)//匹配正則
{
Regex r;
r = new Regex(@str,RegexOptions.IgnoreCase);
return r;
}
/// <summary>
/// 替換
/// </summary>
/// <param name="sDetail">要處理的字符</param>
/// <param name="regex">正則表達(dá)式</param>
/// <param name="replace_str">要替換的內(nèi)容</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;//匹配長(zhǎng)度
cut_str=cut_str.Substring(last_index,cut_str.Length-last_index);//去掉上次后的結(jié)果
int k=cut_str.IndexOf(m.Groups[0].ToString());//當(dāng)前位置
string this_v=cut_str.Substring(k,n);//當(dāng)前匹配的值
string str3=cut_str.Substring(0,k+n);//當(dāng)前得到的值
//return_str+=str3.Replace(m.Groups[0].ToString(),Return_Item_Content(m.Groups[0].ToString()));
return_str+=evn(str3,m);
last_index=k+n;//記錄當(dāng)前匹配的位置
}
if(return_str!="")
sDetail=return_str+cut_str.Substring(last_index,cut_str.Length-last_index);
return sDetail;
}
}
復(fù)制代碼 代碼如下:
str=str.replace(字符串一,字符串二)
不難發(fā)現(xiàn)一個(gè)問題,如果str要循環(huán)替換很多次,下一次替換時(shí)會(huì)累加上上次替換的內(nèi)容,并且全遍歷一次,如果字符串二很多,替換的過程就像階梯效果,越來越大,所以速度越來越慢。要解決這個(gè)問題只能找另外的方法替換這種表達(dá)方式。
如何以更高效率代替這種操作? 思路如下:
每次替換完后,在下次替換時(shí)先排除這次替換的內(nèi)容,累加本次替換的內(nèi)容。
復(fù)制代碼 代碼如下:
public Regex returnMatch(String str)//匹配正則
{
Regex r;
r = new Regex(@str,RegexOptions.IgnoreCase);
return r;
}
/// <summary>
/// 替換
/// </summary>
/// <param name="sDetail">要處理的字符</param>
/// <param name="regex">正則表達(dá)式</param>
/// <param name="replace_str">要替換的內(nèi)容</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;//匹配長(zhǎng)度
cut_str=cut_str.Substring(last_index,cut_str.Length-last_index);//去掉上次后的結(jié)果
int k=cut_str.IndexOf(m.Groups[0].ToString());//當(dāng)前位置
string this_v=cut_str.Substring(k,n);//當(dāng)前匹配的值
string str3=cut_str.Substring(0,k+n);//當(dāng)前得到的值
//return_str+=str3.Replace(m.Groups[0].ToString(),Return_Item_Content(m.Groups[0].ToString()));
return_str+=evn(str3,m);
last_index=k+n;//記錄當(dāng)前匹配的位置
}
if(return_str!="")
sDetail=return_str+cut_str.Substring(last_index,cut_str.Length-last_index);
return sDetail;
}
}
相關(guān)文章
SignalR Self Host+MVC等多端消息推送服務(wù)(三)
這篇文章主要為大家詳細(xì)介紹了SignalR Self Host+MVC等多端消息推送服務(wù)的第三篇,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06ASP.NET實(shí)現(xiàn)的生成驗(yàn)證碼功能示例【附demo源碼】
這篇文章主要介紹了ASP.NET實(shí)現(xiàn)的生成驗(yàn)證碼功能,結(jié)合實(shí)例形式較為詳細(xì)的分析了asp.net生成驗(yàn)證碼的原理、步驟與相關(guān)實(shí)現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-07-07ASP.NET State service狀態(tài)服務(wù)的問題解決方法
每次重啟機(jī)器以后,在.NET2005上跑Web程序老是遇到這樣的問題2008-11-11.net 運(yùn)用二進(jìn)制位運(yùn)算進(jìn)行數(shù)據(jù)庫(kù)權(quán)限管理
.net 運(yùn)用二進(jìn)制位運(yùn)算進(jìn)行數(shù)據(jù)庫(kù)權(quán)限管理 ,需要的朋友可以參考一下2013-02-02詳解.NET Core使用Quartz執(zhí)行調(diào)度任務(wù)進(jìn)階
這篇文章主要介紹了.NET Core使用Quartz執(zhí)行調(diào)度任務(wù)進(jìn)階,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04ASP.NET網(wǎng)站導(dǎo)航及導(dǎo)航控件如何使用
這篇文章主要介紹了ASP.NET網(wǎng)站導(dǎo)航及導(dǎo)航控件如何使用,需要的朋友可以參考下2015-09-09Entity Framework Core更新時(shí)間映射
這篇文章介紹了Entity Framework Core更新時(shí)間映射的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03