python 实现 urlencode 与 urldecode (中文及特殊字符编解码)

这里说的urlencode非python自带的urlencode是与

http://tool.chinaz.com/Tools/URLEncode.aspx 相同功能的函数 

初学python 风格较烂 勿喷。


# -*- coding: UTF-8 -*-

#编码
def urlencode_pl(inputs_str):
	len_str=len(inputs_str)
	if str=="" or len_str<=0:
		return ""
	index_j=0
	index_i=0
	result_end=""
	for index_i in range(0,len_str):
		index_sb=index_i+1
		chs=inputs_str[index_i:index_sb]
		if (chs>='A' and chs<'Z') or (chs>='a' and chs<'z') or (chs>='0' and chs<'9'):
			if result_end=="":
				result_end=chs
			else:
				result_end+=chs
		elif chs==' ':
			result_end+='+'
		elif chs=='.' or chs=='-' or chs=='_' or chs=='*':
			result_end+=chs
		else:
			result_end='%s%%%02X' % (result_end,ord(chs))


	return result_end

#解码
def urldecode_pl(srcstr):
    dststr=""
    leng=len(srcstr)
    temp1=""
    temp2=""
    i=0;
    while i<leng:
        temp1="\0";
        temp2="\0";
        if(srcstr[i:i+1]!="%" and srcstr[i:i+1]!="+"):
            dststr=dststr+srcstr[i:i+1];
            i=i+1;
            continue
        elif(srcstr[i:i]=="+"):
            dststr=dststr+" ";
            i=i+1;
            continue
        temp1=srcstr[i+1:i+2];
        temp2=srcstr[i+2:i+3];
        sb1=0;
        sb2=0;
        if(cmp(temp1,"A")>=0):
            sb1=7;
        if(cmp(temp1,"a")>=0):
            sb2=32;
        temp1=ord(temp1)-48-sb1-sb2
        
        sb1=0;
        sb2=0;
        
        if(cmp(temp2,"A")>=0):
            sb1=7;
        if(cmp(temp2,"a")>=0):
            sb2=32;
        temp2=ord(temp2)-48-sb1-sb2


        dststr=dststr+chr(temp1*16+temp2);
        i=i+3;
    return dststr;

#main函数 
if __name__ == '__main__':
	strs="sanya.ganji.com/huangye/a3/s/c/_大众"
	print strs
	str2=urlencode_pl(strs);
	print str2;
	str3=urldecode_pl(str2)
	print str3;
	str4=urldecode_pl(strs)
	print str4



运行 python XX.py

结果如下:

原始字符串:sanya.ganji.com/huangye/a3/s/c/_大众 
编码字符串:sanya.ganji.com%2Fhuangye%2Fa3%2Fs%2Fc%2F_%E5%A4%A7%E4%BC%97
编码解码字符串:sanya.ganji.com/huangye/a3/s/c/_大众



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的`urlencode`和`urldecode`是用于处理URL编码和解码的方法。 `urlencode`方法用于将一个字典形式的参数列表转换为URL编码的字符串。例如,假设有一个字典`params`包含以下键值对: ``` params = {"name": "张三", "age": 20, "city": "北京"} ``` 使用`urlencode`方法将字典转换为URL编码的字符串: ``` import urllib.parse url_encoded = urllib.parse.urlencode(params) print(url_encoded) ``` 输出结果为: ``` name=%E5%BC%A0%E4%B8%89&age=20&city=%E5%8C%97%E4%BA%AC ``` `urldecode`方法用于将URL编码的字符串解码为字典形式的参数列表。例如,将上面的URL编码字符串解码为字典: ```python import urllib.parse url_decoded = urllib.parse.parse_qs(url_encoded) print(url_decoded) ``` 输出结果为: ``` {'name': ['张三'], 'age': ['20'], 'city': ['北京']} ``` 可以通过访问字典的键来获取对应的值: ```python name = url_decoded['name'][0] age = url_decoded['age'][0] city = url_decoded['city'][0] print(f"姓名:{name},年龄:{age},城市:{city}") ``` 输出结果: ``` 姓名:张三,年龄:20,城市:北京 ``` 通过这两个方法,我们可以方便地进行URL编码和解码的操作,以便于在HTTP请求或其他URL相关的场景中使用。 ### 回答2: Python中的urlencode方法是将字典数据编码URL参数的字符串。它将字典键值对转换为一组key=value对,并用&符号链接起来。这通常用于构建GET请求的URL参数部分。 例如,将以下字典数据编码URL参数字符串: ``` params = {'name': '张三', 'age': 20, 'city': '北京'} ``` 通过使用urlencode方法,我们可以得到如下结果: ``` encoded_params = urllib.parse.urlencode(params) print(encoded_params) ``` 输出结果为:name=%E5%BC%A0%E4%B8%89&age=20&city=%E5%8C%97%E4%BA%AC urldecode的功能与urlencode相反,它用于将URL参数字符串解码为字典数据。例如,将上面编码后的字符串解码为字典数据: ``` decoded_params = urllib.parse.parse_qs(encoded_params) print(decoded_params) ``` 输出结果为:{'name': ['张三'], 'age': ['20'], 'city': ['北京']} 注意,这里使用了urllib.parse模块来进行编码和解码。在Python 3中,urllib模块已经被拆分为多个子模块,其中urllib.parse包含了URL编码和解码相关的功能。 综上所述,Python中的urlencodeurldecode方法提供了方便的对URL参数进行编码和解码的功能,可以用于构建和解析GET请求的URL参数部分。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值