微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

VB中UTF8转Unicode编码

 
 
  1. PrivateDeclareFunctionMultiBytetoWideCharLib"kernel32"(ByValCodePageAsLong,ByValdwFlagsAsLong,ByReflpMultiByteStrAsAny,ByValcchMultiByteAsLong,ByVallpWideCharStrAsLong,ByValcchWideCharAsLong)AsLong
  2. PrivateConstCP_UTF8=65001
  3. 'Purpose:ConvertUtf8toUnicode
  4. PublicFunctionUTF8_Decode(ByValsUTF8AsString)AsString
  5. DimlngUtf8SizeAsLong
  6. DimstrBufferAsString
  7. DimlngBufferSizeAsLong
  8. DimlngResultAsLong
  9. DimbytUtf8()AsByte
  10. DimnAsLong
  11. IfLenB(sUTF8)=0ThenExitFunction
  12. OnErrorGoToEndFunction
  13. bytUtf8=StrConv(sUTF8,vbFromUnicode)
  14. lngUtf8Size=UBound(bytUtf8)+1
  15. OnErrorGoTo0
  16. lngBufferSize=lngUtf8Size*2
  17. strBuffer=String$(lngBufferSize,vbNullChar)
  18. 'Translateusingcodepage65001(UTF-8)
  19. lngResult=MultiBytetoWideChar(CP_UTF8,bytUtf8(0),_
  20. lngUtf8Size,StrPtr(strBuffer),lngBufferSize)
  21. 'Trimresulttoactuallength
  22. IflngResultThen
  23. UTF8_Decode=Left$(strBuffer,lngResult)
  24. EndIf
  25. EndFunction

把你上面获取内容转一下就行,比如Text1.Text=UTF8_Decode(strResponse) 还可以加多一句InStr(1,strResponse,"charset=utf-8") > 0判断是否是UTF8编码再执行,不是UTF8的就直接显示。 还有些网页编码那里是大写的,要这样写InStr(1,"charset=UTF-8") > 0

原文地址:https://www.jb51.cc/vb/260595.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐