python 编码问题

对于python的字符串来说。如果是a = 'abc',这就是代表是一个正常的字符串类型为str。如果是a= b'abc'这就代表着一个bytes object。对于bytes object 来说,可以使用decode而非encode;对于正常字符串而言可以使用encode,但是却不能使用decode.如果想将bytes object直接转换为字符串型,可以使用str()或者repr()。但是这里对于已经进行编码的字符串而言,这样做没有任何好处。

今天碰到一个一个问题,使用python取得网页内容的时候:

这里content就是一个bytes object.如果使用正则式title[/d/D]*?title就会失效,抛出exception,说不能将findall(),finditer()等函数用在bytes object上。所以要进行decode()

代码如下:

如果想搜索中文,正则式中也可以放入中文。

还有一点不好的地方,就在于这个decode()中到底放入什么编解码方式。这取决于那个网页的信息了。一般都会给出。csdn.net给出的就是charset=utf-8.也可以使用下面的代码得到编解码方式:

可惜的一点是,这里的information是字符串型。传说它是http.client.HTTPMessage的实例并且 继承了email.message.Message。根据文档说是用information.get_charset()就能得到编码是啥类型。可惜我没有试出来,返回值为None.使用csdn的例子可以得到info的信息为:

Server: nginx/0.6.36
Date: Sun, 16 Aug 2009 15:51:04 GMT
Content-Type: text/html; charset=utf-8
Connection: close
Vary: Accept-Encoding
Cache-Control: max-age=604800
Content-Length: 109205
Content-Location: http://www.csdn.net/index.htm
Last-Modified: Sat, 15 Aug 2009 11:11:04 GMT
Accept-Ranges: bytes
ETag: "f4756814991dca1:aa9"
X-Powered-By: ASP.NET
X-UA-Compatible: IE=EmulateIE7
Age: 19
X-Cache: HIT from FECACHE
X-Cache-Lookup: HIT from FECACHE:80
Via: 1.0 cachedev.CSDN.NET (WebCache)

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值