今天有个《批处理怎样把文本的字符串编码化urlencode?》的帖子,里面有人回复了个VBS版的urlencode,但是那个是ANSI版的,别人要的是UTF-8版的。
很久很久以前写过,发上来,虽然不会有人看。
UTF-8版 | | | | | | | | | Function urlencode(str) | | Dim i,c,s,length | | length = Len(str) | | For i = 1 To length | | s = Mid(str,i,1) | | c = "&H" & Hex(AscW(Mid(str,i,1))) | | If ( c >= AscW("A") And c <= AscW("Z") ) Or _ | | ( c >= AscW("a") And c <= AscW("z") ) Or _ | | ( c >= AscW("0") And c <= AscW("9") ) Or _ | | ( c = AscW("-") Or c = AscW("_") Or c = AscW(".") ) Then | | urlencode = urlencode & s | | ElseIf c = AscW(" ") Then | | urlencode = urlencode & "+" | | Else | | If c >= &H0001 And c <= &H007F Then | | urlencode = urlencode & s | | ElseIf c > &H07FF Then | | urlencode = urlencode & "%" & Hex(&HE0 Or (c\(2^12) And &H0F)) | | urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^6) And &H3F)) | | urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^0) And &H3F)) | | Else | | urlencode = urlencode & "%" & Hex(&HC0 Or (c\(2^6) And &H1F)) | | urlencode = urlencode & "%" & Hex(&H80 Or (c\(2^0) And &H3F)) | | End If | | End If | | Next | | End Function | | | | WScript.Echo urlencode("知道")COPY |
ANSI版 | | | | | | | | | Function urlencode(str) | | Dim i,c,s,length | | length = Len(str) | | For i = 1 To length | | s = Mid(str,i,1) | | c = Asc(Mid(str,i,1)) | | If ( c >= Asc("A") And c <= Asc("Z") ) Or _ | | ( c >= Asc("a") And c <= Asc("z") ) Or _ | | ( c >= Asc("0") And c <= Asc("9") ) Or _ | | ( c = Asc("-") Or c = Asc("_") Or c = Asc(".") ) Then | | urlencode = urlencode & s | | ElseIf c = Asc(" ") Then | | urlencode = urlencode & "+" | | Else | | urlencode = urlencode & "%" & Left(Hex(c),2) | | urlencode = urlencode & "%" & Right(Hex(c),2) | | End If | | Next | | End Function | | | | WScript.Echo urlencode("知道")COPY |
|