找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 23187|回复: 2

[原创] 用VBS实现urlencode(UTF-8 ANSI)

[复制链接]
发表于 2011-6-1 20:00:54 | 显示全部楼层 |阅读模式
今天有个《批处理怎样把文本的字符串编码化urlencode?》的帖子,里面有人回复了个VBS版的urlencode,但是那个是ANSI版的,别人要的是UTF-8版的。

很久很久以前写过,发上来,虽然不会有人看。

UTF-8版

  1. 'Date: 2010/6/18
  2. 'Author: Demon
  3. 'Website: http://demon.tw

  4. Function urlencode(str)
  5.     Dim i,c,s,length
  6.     length = Len(str)
  7.     For i = 1 To length
  8.         s = Mid(str,i,1)
  9.         c = "&H" & Hex(AscW(Mid(str,i,1)))
  10.         If ( c >= AscW("A") And c <= AscW("Z") ) Or _
  11.             ( c >= AscW("a") And c <= AscW("z") ) Or _
  12.             ( c >= AscW("0") And c <= AscW("9") ) Or _
  13.             ( c = AscW("-") Or c = AscW("_") Or c = AscW(".") ) Then
  14.             urlencode = urlencode & s
  15.         ElseIf c = AscW(" ") Then
  16.             urlencode = urlencode & "+"
  17.         Else
  18.             If c >= &H0001 And c <= &H007F Then
  19.                 urlencode = urlencode & s
  20.             ElseIf c > &H07FF Then
  21.                 urlencode = urlencode & "%" & Hex(&HE0 Or (c\(2^12) And &H0F))
  22.                 urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^6) And &H3F))
  23.                 urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^0) And &H3F))
  24.             Else
  25.                 urlencode = urlencode & "%" & Hex(&HC0 Or (c\(2^6) And &H1F))
  26.                 urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^0) And &H3F))
  27.             End If
  28.         End If
  29.     Next
  30. End Function

  31. WScript.Echo urlencode("知道")
复制代码
ANSI版

  1. 'Date: 2010/6/18
  2. 'Author: Demon
  3. 'Website: http://demon.tw

  4. Function urlencode(str)
  5.         Dim i,c,s,length
  6.         length = Len(str)
  7.         For i = 1 To length
  8.                 s = Mid(str,i,1)
  9.                 c = Asc(Mid(str,i,1))
  10.                 If ( c >= Asc("A") And c <= Asc("Z") ) Or _
  11.                         ( c >= Asc("a") And c <= Asc("z") ) Or _
  12.                         ( c >= Asc("0") And c <= Asc("9") ) Or _
  13.                         ( c = Asc("-") Or c = Asc("_") Or c = Asc(".") ) Then
  14.                         urlencode = urlencode & s
  15.                 ElseIf c = Asc(" ") Then
  16.                         urlencode = urlencode & "+"
  17.                 Else
  18.                         urlencode = urlencode & "%" & Left(Hex(c),2)
  19.                         urlencode = urlencode & "%" & Right(Hex(c),2)                       
  20.                 End If
  21.         Next
  22. End Function

  23. WScript.Echo urlencode("知道")
复制代码

评分

参与人数 2技术 +2 收起 理由
rzzm + 1 初学脚本,发现国内外vbs玩得最溜的就是你了 ...
tmplinshi + 1 感谢分享

查看全部评分

 楼主| 发表于 2011-6-1 20:01:32 | 显示全部楼层
参数都是VBS字符串
发表于 2012-7-5 19:52:47 | 显示全部楼层
Thanks a lot.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 06:26 , Processed in 0.023453 second(s), 12 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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