程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> 用C#截取指定長度的中英文混合字符串

用C#截取指定長度的中英文混合字符串

編輯:關於C#

我們常做的一件事情,就是在文章系統中,截取一定長度的文章標題,超過指定長度,就加“...”

如兩個字符串:

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);

http://yao.cnblogs.com/archive/2006/07/04/442886.html

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved