VB中UTF8转Unicode编码

前端之家收集整理的这篇文章主要介绍了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

猜你在找的VB相关文章