利用DHT网络原理制作bt采集蜘蛛,开源版

由于中文的特殊性,造成了在各大编程语言中都存在编码转换的问题,今天我们来探讨下python中中文编码如何处理呢
首先,要明白encode()和decode()的区别找了台服务器将磁力链接爬虫架设起来http://www.51bt.cc(51搜索)大家可以看下。 


 encode()的作用是将Unicode编码的字符串转换为其他编码格式。


例如: st1.encode("utf-8")  这句话的作用是将Unicode编码的st1编码为utf-8编码的字符串


decode()的作用是把其他编码格式的字符串转换成Unicode编码的字符串。


例如: st2.decode("utf-8") 这句话的作用是将utf-8编码的字符串st2解码为Unicode编码的字符串


第二,除Unicode编码的字符串以外,任何一种编码的字符串要想转换为其他编码格式,必须先解码后编码


非Unicode编码--> Unicode编码-->非Unicode编码


例如,utf-8编码的字符串st想要转换为gbk编码的字符串,必须经过以下步骤:


st=st.decode("utf-8") #解码为Unicode编码


st=st.encode("gbk")  #从Unicode编码编码为gbk编码


第三,我们经常使用的utf-8编码还分为有BOM的和无BOM的。


第四:关于json文件的中文编码。用Python读取Json文件时经常用到json.load()函数,该函数对json文件的格式是有要求的


1)json文件是utf-8 without BOM编码的,那么可以直接用json.load(filename)函数读取json文件的内容


2)json文件是utf-8 with BOM编码的,不能用json.load()函数读取,json.load()不能正确识别


3)json文件时其他编码的,比如gbk, 要把json文件的编码格式作为一个参数传给json.load():


eg. json.load(filename,"gbk")


第五,怎么查看并且设置自己文件的编码呢?


介绍一个个人比较喜欢的工具"Nodtepad++",随便一个软件管家里就与一键安装。


用这个工具你可以方便的查看自己的文件的当前编码,并可以轻松转换成任意其他编码格式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值