我們常做的一件事情,就是在文章系統中,截取一定長度的文章標題,超過指定長度,就加“...”
如兩個字符串:
string str1 = "中國人要啊abc呀~";
string str2 = "1中國人23456abc呀~";
要截取後,輸出:
str1 = "中國人要...";
str2 = "1中國人2...";
即要把中英文混合的字符串,在截取後,長度要一致,即8個字節的長度(不包括三個點),而且不能出現中文被從中間截斷的情況。於是寫了個方法:
public static string getStr(string s,int l)
{
string temp = s ;
if (Regex.Replace(temp,"[\u4e00-\u9fa5]","zz",RegexOptions.IgnoreCase).Length<=l)
{
return temp;
}
for (int i=temp.Length;i>=0;i--)
{
temp = temp.Substring(0,i);
if (Regex.Replace(temp,"[\u4e00-\u9fa5]","zz",RegexOptions.IgnoreCase).Length<=l-3)
{
return temp + "";
}
}
return "";
}
調用:
string content = "中國人啊abc呀呀呀呀";
content = getStr(content,13);