1、这是在网上找的
利用正则表达式计算含有中文的字符串长度
[QUOTE][code]
using System;
using System.Text.RegularExpressions;
namespace LangZi
{
/** <summary>
/// StringHelper 的摘要说明。
/// </summary>
public class StringHelper
{
public StringHelper()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
GetLength#region GetLength
/** <summary>
/// 返回包含中文字符的字符串长度
/// C# 的string.Length中中文字只做1位统计,所以要将其转换为2位
/// </summary>
/// <param >要统计长度的字符串变量</param>
/// <returns>字符串长度</returns>
public static int GetLength(string strSource)
{
Regex regex = new Regex("[/u4e00-/u9fa5]+", RegexOptions.Compiled);
int nLength = strSource.Length;
for(int i=0; i<strSource.Length; i++)
{
if (regex.IsMatch(strSource.Substring(i,1)))
{
nLength++;
}
}
return nLength;
}
#endregion
}
}
[/code]
2、这是自己改写的
public static int GetLength(string strSource)
{
MatchCollection Matches = Regex.Matches(strSource, "[/u4e00-/u9fa5]+", RegexOptions.IgnoreCase);
StringBuilder sb = new StringBuilder();
foreach (Match NextMatch in Matches)
{
sb.Append(NextMatch.Value);
}
return strSource.Length + sb.ToString().Length;
}
还有用这个正则表达式也可以判断:"[^/x00-/xff]*";
但是当出现中文状态下的标点的时候他也会判断成2个字节。
根据你的需要自行判断需要的表达式