VB 汉字字符串的截取LEN、LEFT、RIGHT

自从VB4.0后,就把汉字看做是1个字符了。这给我们的字符串的截取带来了严重的麻烦!

如果是汉字+数字或字母的字符串,往往截取到的字符串长度不是理想中的,其中涉及到的函数有LEN、LEFT、RIGHT我自己编写了如下3个函数,用来取代 len()、left()、right(),希望能解决您的问题。'--------------------------------------------------------'Name:lenX'Argument:uStr'Return:'Description:返回字符串的长度,1个中文字符长度为2'--------------------------------------------------------function lenX(byval uStr)dim theLen,x,testuStrtheLen = 0for x = 1 to len(uStr)testuStr = mid(uStr,1)if asc(testuStr) < 0 thentheLen = theLen + 2elsetheLen = theLen + 1end ifnextlenX = theLenend function'--------------------------------------------------------'Name:leftX'Argument:uStr待处理的字符串'uLen要截取的长度'Return:'Description:返回指定长度的字符串,1个中文字符长度为2'--------------------------------------------------------function leftX(byval uStr,byval uLen)dim i,j,uTestStr,theStrleftX = ""j = 0for i = 1 to len(uStr)uTestStr= mid(uStr,i,1)theStr= theStr & uTestStrif asc(uTestStr) < 0 thenj = j + 2elsej = j + 1end ifif j >= uLen then exit fornextleftX = theStrend function'--------------------------------------------------------'Name:rightX'Argument:uStr待处理的字符串'uLen要截取的长度'Return:'Description:返回指定长度的字符串,1个中文字符长度为2'--------------------------------------------------------function rightX(byval uStr,uTestStrrightX = ""j = 0for i = len(uStr) to 1 step -1uTestStr = mid(uStr,1)rightX = rightX & uTestStrif asc(uTestStr) < 0 thenj = j + 2elsej = j + 1end ifif j >= uLen then exit fornextend function

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...