asp.net高效替換大容量字元實現代碼

來源:互聯網
上載者:User

一般進行替換操作都這樣: 複製代碼 代碼如下: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">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;
}
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.