设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12下一页
返回列表 发新帖
查看: 1545|回复: 11
打印 上一主题 下一主题

[查询] 关于字符个数判断的问题!?

[复制链接]
跳转到指定楼层
1#
发表于 2008-10-25 14:44:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
A=我喜欢你
B=a2-4喜欢
len(A)=4
len(B)=6
可在打印时“我喜欢你”和“a2-4喜欢”占用的物理长度是一样的,如何能得出A的字符数和B的字符数都为8(汉字为双字节),或者用其他方法判断出其占用的物理长度一样啊!?

[ 本帖最后由 sxgaobo 于 2008-10-25 16:29 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2008-10-25 15:37:04 | 只看该作者
我用论坛里的一个示例,在超市小票上用到过。
3#
 楼主| 发表于 2008-10-25 15:45:18 | 只看该作者
能告诉我方法吗
4#
 楼主| 发表于 2008-10-26 09:14:34 | 只看该作者
自己顶
5#
 楼主| 发表于 2008-10-27 08:47:02 | 只看该作者
[:24] 帮忙啊大侠们!
6#
发表于 2008-10-27 10:51:37 | 只看该作者
先判断有几个汉字
7#
 楼主| 发表于 2008-10-27 13:58:17 | 只看该作者
麻烦指明怎么判断好吗?
8#
发表于 2008-10-27 14:51:57 | 只看该作者
原帖由 sxgaobo 于 2008-10-27 13:58 发表
麻烦指明怎么判断好吗?


我只知道汉字的asc值为负数,但不知道asc值为负数的是不是一定是汉字。
你可以试试,大家共同探讨

Public Function ChnNum(strChnIn As String) As Long
    Dim I As Integer
    Dim lngTemp As Long
    For I = 1 To Len(strChnIn)
        If Asc(Mid(strChnIn, I, 1)) < 0 Then
            lngTemp = lngTemp + 1
        End If
    Next
    ChnNum = lngTemp
End Function

如果上面的函数是正确的
哪么,你的结果应该是
=Len(strChnIn)+ChnNum(strChnIn)
9#
 楼主| 发表于 2008-10-27 15:41:17 | 只看该作者
谢谢!!!高手
10#
发表于 2008-10-27 23:45:20 | 只看该作者
sub a
Dim ls1, ls2 As String
      ls1 = "a2-4喜欢"
       ls2 = StrConv(ls1, vbFromUnicode)         
  Debug.Print LenB(ls2)
end sub
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-19 06:30 , Processed in 0.082247 second(s), 34 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表