C#区分中英文按照指定长度截取字符串的方法

本文实例讲述了C#区分中英文按照指定长度截取字符串的方法。

分享给大家供大家参考。

具体如下:

这段C#代码用于按照指定的长度截取字符串,一个中文字符算2个字符,按照这个方法截取的字符串基本可以保持显示长度一致


///  
/// 截取文本,区分中英文字符,中文算两个长度,英文算一个长度
/// 
/// 待截取的字符串
/// 需计算长度的字符串
/// string
public static string GetSubString(string str, int length)
{
  string temp = str;
  int j = 0;
  int k = 0;
  for (int i = 0; i < temp.Length; i++)
  {
 if (Regex.IsMatch(temp.Substring(i, 1), @"[u4e00-u9fa5]+"))
 {
   j += 2;
 }
 else
 {
   j += 1;
 }
 if (j <= length)
 {
   k += 1;
 }
 if (j > length)
 {
   return temp.Substring(0, k) + "..";
 }
  }
  return temp;
}

希望本文所述对大家的C#程序设计有所帮助。

0.222000s