中文字符转换

发布网友 发布时间:2022-04-20 22:42

我来回答

4个回答

热心网友 时间:2023-09-18 13:43

如果你懂得ASP的话,很容易解释那串编码的来源:
在ASP中Server对象有个函数是URLEncode,它的功能是将汉字编码转换成URL专用格式。
str=server.URLEncode("瘪三")
之后str的值就是%B1%F1%C8%FD了。
这就是%B1%F1%C8%FD的来源。
URLEncode的算法和二楼解释一样:
把汉字转化为ASCII,然后转化为16进制,将其每阁两字符加%

至于目的,和1楼的说法相似。
汉字通过URL直接传常出现意想不到的错误,所以用这个东西。
下面的一个简单示例程序可以输出某个汉字的GB2312编码,不过在TC下不支持输入中文,你可以用VC或者Dev-CPP编译。(下面程序没有编写容错的代码,只是为了简单说明一下)
main()
{
char buf[3];
scanf("%s",buf); //输入一个汉字,如果多于一个汉字会出错
printf("%x%x\n",buf[0]&0xFF,buf[1]&0xFF);
//跟0xFF做&运算是为了确保输出正数
return 0;

热心网友 时间:2023-09-18 13:44

你错了,那个不是什么格式转换,而是正则表达式
正则表达式用于查看字符的匹配情况,现在很多搜索引擎都是用正则表达式的。关于正则表达式的使用规则很简单,你这要随便搜一下就可以了,保证你能在半天内掌握,甚至2~3个小时就够了

热心网友 时间:2023-09-18 13:44

保存为html文件,运行就可以转换了

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> URLDecode </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>

<BODY>
URLDecoder<br />
<TEXTAREA NAME="txtCode" ROWS="5" COLS="80"></TEXTAREA><br />
<INPUT TYPE="submit" onclick="vbscript:txtText.value=URLDecode(txtCode.value)"><br />
<TEXTAREA NAME="txtText" ROWS="5" COLS="80"></TEXTAREA>
<SCRIPT LANGUAGE="VBScript">
<!--
Public Function LShift(ByVal lValue, ByVal iShiftBits)
LShift = lValue * (2 ^ iShiftBits)
End Function

Public Function RShift(ByVal lValue, ByVal iShiftBits)
RShift = lValue \ (2 ^ iShiftBits)
End Function

Function Hex2Dec(ByVal sHex)
sHex=UCase(sHex)
For i=1 To Len(sHex)
byChar=Asc(Mid(sHex,i,1))
If byChar>57 Then
byChar=byChar-65+10
Else
byChar=byChar-48
End If
lReturn=lReturn+byChar*16^(Len(sHex)-i)
Next
Hex2Dec=lReturn
End Function
'%B1%F1%C8%FD
Function URLDecode(ByVal sHex)
Dim sText
Dim i
Dim lChar,byChar,byChar2,lUniCount
Dim sByte
sHex = UCase(Replace(sHex, vbCrLf, ""))
If Left(sHex,1)="%" Then sHex=Right(sHex,Len(sHex)-1)
sByte = Split(sHex, "%")
For i = 0 To UBound(sByte)
byChar = Hex2Dec(sByte(i))
If byChar>128 Then
lUniCount=lUniCount+1
If lUniCount Mod 2 = 0 Then
lChar=LShift(byChar2, 8) Or byChar
sText = sText & Chr(lChar)
End If
byChar2=byChar
Else
sText = sText & Chr(byChar)
End If
Next
URLDecode=sText
End Function
//-->
</SCRIPT>
</BODY>
</HTML>

热心网友 时间:2023-09-18 13:45

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> URLDecode </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>

<BODY>
URLDecoder<br />
<TEXTAREA NAME="txtCode" ROWS="5" COLS="80"></TEXTAREA><br />
<INPUT TYPE="submit" onclick="vbscript:txtText.value=URLDecode(txtCode.value)"><br />
<TEXTAREA NAME="txtText" ROWS="5" COLS="80"></TEXTAREA>
<SCRIPT LANGUAGE="VBScript">
<!--
Public Function LShift(ByVal lValue, ByVal iShiftBits)
LShift = lValue * (2 ^ iShiftBits)
End Function

Public Function RShift(ByVal lValue, ByVal iShiftBits)
RShift = lValue \ (2 ^ iShiftBits)
End Function

Function Hex2Dec(ByVal sHex)
sHex=UCase(sHex)
For i=1 To Len(sHex)
byChar=Asc(Mid(sHex,i,1))
If byChar>57 Then
byChar=byChar-65+10
Else
byChar=byChar-48
End If
lReturn=lReturn+byChar*16^(Len(sHex)-i)
Next
Hex2Dec=lReturn
End Function
'%B1%F1%C8%FD
Function URLDecode(ByVal sHex)
Dim sText
Dim i
Dim lChar,byChar,byChar2,lUniCount
Dim sByte
sHex = UCase(Replace(sHex, vbCrLf, ""))
If Left(sHex,1)="%" Then sHex=Right(sHex,Len(sHex)-1)
sByte = Split(sHex, "%")
For i = 0 To UBound(sByte)
byChar = Hex2Dec(sByte(i))
If byChar>128 Then
lUniCount=lUniCount+1
If lUniCount Mod 2 = 0 Then
lChar=LShift(byChar2, 8) Or byChar
sText = sText & Chr(lChar)
End If
byChar2=byChar
Else
sText = sText & Chr(byChar)
End If
Next
URLDecode=sText
End Function
//-->
</SCRIPT>
</BODY>
</HTML>

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com