脚本专栏 
首页 > 脚本专栏 > 浏览文章

python3中bytes和string之间的互相转换

(编辑:jimmy 日期: 2024/5/9 浏览:3 次 )

前言

Python 3最重要的新特性大概要算是对文本和二进制数据作了更为清晰的区分。文本总是Unicode,由str类型表示,二进制数据则由bytes类型表示。Python 3不会以任意隐式的方式混用str和bytes,正是这使得两者的区分特别清晰。你不能拼接字符串和字节包,也无法在字节包里搜索字符串(反之亦然),也不能将字符串传入参数为字节包的函数(反之亦然).

python3.0中怎么创建bytes型数据

bytes([1,2,3,4,5,6,7,8,9])
bytes("python", 'ascii') # 字符串,编码

首先来设置一个原始的字符串,

Python 3.2.3 (default, Apr 11 2012, 07:15:24) [MSC v.1500 32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.
> website = 'https://www.jb51.net/'
> type(website)
<class 'str'>
> website
'https://www.jb51.net/'
>

按utf-8的方式编码,转成bytes

> website_bytes_utf8 = website.encode(encoding="utf-8")
> type(website_bytes_utf8)
<class 'bytes'>
> website_bytes_utf8
b'https://www.jb51.net/'
>

按gb2312的方式编码,转成bytes

> website_bytes_gb2312 = website.encode(encoding="gb2312")
> type(website_bytes_gb2312)
<class 'bytes'>
> website_bytes_gb2312
b'https://www.jb51.net/'
>

解码成string,默认不填

> website_string = website_bytes_utf8.decode()
> type(website_string)
<class 'str'>
> website_string
'https://www.jb51.net/'
>
>

解码成string,使用gb2312的方式

> website_string_gb2312 = website_bytes_gb2312.decode("gb2312")
> type(website_string_gb2312)
<class 'str'>
> website_string_gb2312
'https://www.jb51.net/'
>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

上一篇:Python使用QQ邮箱发送Email的方法实例
下一篇:python实现下载文件的三种方法
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网