[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
2# broly
实际上用u4e00-u9fa5区间来判断汉字是非常不准确的
其实在国内范围用判断字符高位是不是0x00的方法更为准确有效
见下面的代码示例:
  1. Dim vbStr, Str, HexCode, OutStr1, OutStr2
  2. '提取汉字
  3. vbStr = "[精品展示]一个纯批处理备份&还原驱动"
  4. For i = 1 To Len(vbStr)
  5.   Str = Mid(vbStr, i, 1)
  6.   If Ascb(Midb(Str, 2, 1)) <> 0 Then
  7.     OutStr1 = OutStr1 & Str  
  8.     HexCode = Hex(Ascb(Midb(Str, 2, 1))) & Hex(Ascb(Midb(Str, 1, 1)))
  9.     If HexCode => "4e00" And HexCode <= "9fa5" Then OutStr2 = OutStr2 & Mid(vbStr, i, 1)
  10.   End If
  11. Next
  12. MsgBox "高位判断法:" & OutStr1 & vbCrLf & "区间判断法:"  & OutStr2
复制代码
一路飘过的鸟~~~

TOP

楼上大错特错
没注意<=>是区分大小写的还有高位为个位数的情况
证明这个区间判断法还是可以的
修改如下:
  1. Dim vbStr, Str, HexCode, OutStr1, OutStr2
  2. '提取汉字
  3. vbStr = "[精品展示]一个纯批处理备份&还原驱动"
  4. For i = 1 To Len(vbStr)
  5.   Str = Mid(vbStr, i, 1)
  6.   If Ascb(Midb(Str, 2, 1)) <> 0 Then
  7.     OutStr1 = OutStr1 & Str  
  8.     HexCode = Hex(Ascw(str))
  9.     If HexCode => "4E00" And HexCode <= "9FA5" Then OutStr2 = OutStr2 & Mid(vbStr, i, 1)
  10.   End If
  11. Next
  12. MsgBox "高位判断法:" & OutStr1 & vbCrLf & "区间判断法:"  & OutStr2
复制代码
1

评分人数

一路飘过的鸟~~~

TOP

返回列表