当我们通过Textbox控件向数据库中添加内容时,有时为了程序的可靠性,往往需要限定Textbox中输入内容的长度,以吻合数据库中定义的长度。Textbox控件本身有个maxlength属性,它可以限制Textbox中输入字符的最大长度,所以在只有字符输入的情况下,该属性可以很好的帮助我们达到限制输入长度的目的。但如果输入包含中文或中英文混合的内容时,该属性就不那么完善了,因为它没有把一个汉字当作两个字符来处理,所以这通常会对一些刚刚接触Textbox控件编程的朋友造成些许的小麻烦。为了解决这个问题,我们先来简单分析一下,然后给出一个解决示例,希望能抛砖引玉。
Textbox控件中的text是string类型的,该类型是unicode编码,所以我只需获取中文的unicode值范围,然后对string逐个进行分析,如果在中文unicode值范围内就加2,否则就加1。如此,便可以得到Textbox中包含中英文混合内容的实际长度。
注:前128个Unicode字符(16位代码从0x0000到0x007F)就是ASCII字符,接下来的128个Unicode字符(代码从0x0080到0x00FF)是ISO 8859-1对ASCII的扩展。
* 中国、日本和韩国的象形文字(总称为CJK)占用了从0x3000到0x9FFF的代码
* 希腊字母表使用从0x0370到0x03FF的代码
* 斯拉夫语使用从0x0400到0x04FF的代码
* 美国使用从0x0530到0x058F的代码
* 希伯来语使用从0x0590到0x05FF的代码
简单代码实现: 1public static int GetTextBoxLength(string textboxTextStr)
2 {
3 int nLength = 0;
4 for (int i = 0; i < textboxTextStr.Length; i++)
5 {
6 if (textboxTextStr[i] >= 0x3000 && textboxTextStr[i] <= 0x9FFF)
7 nLength += 2;
8 else
9 nLength++;
10 }
11 return nLength;
12 }
///
#1楼2007-05-09 00:02 | Icebird
我用这个来取字符串长度
byte[] utf8 = Encoding.UTF8.GetBytes(str);
byte[] gb2312 = Encoding.Convert(Encoding.UTF8, Encoding.GetEncoding("gb2312"), utf8);
gb2312.Length就是字符串长度了
///
2007-05-09 08:06 | 预备役中尉
我是这么写的
/** <summary>
2 /// 返回包含中文字符的字符串长度。
3 /// C# 的string.Length中中文字只做1位统计,所以要将其转换为2位
4 /// </summary>
5 /// <param name="strSource">要统计长度的字符串变量</param>
6 /// <returns>字符串长度</returns>
7 public static int GetLength(string strSource)
8 {
9 return Encoding.GetEncoding("GB2312").GetBytes(strSource).Length;
10 }
/
如果是汉字和字母混和的
public void getStringLen(Str)
{
var i,len,code;
if(Str==null || Str == "") return 0;
len = Str.length;
for (i = 0;i < Str.length;i++)
{
code = Str.charCodeAt(i);
if (code > 255) {len ++;}
}
return len;
}
把TextBox1.Text传过去就行了
要是没有汉字
int Len = textbox.text.Length;就行了
/
如果想获得字节长度的话,要看你用什么字符集。
因为.net中的字符串都是unicode的。每个字符两个字节,
英文字母也是。
取得字节数,要针对不同的字符集进行。代码如下。
Encoding enc = Encoding.GetEncoding(字符集名称);
enc.GetByteCount(strValidate)