在Python3中,bytes和str的互相转换⽅式是
bytes.decode('utf-8')
字符串前加 b
python3.x⾥默认的str是(py2.x⾥的)unicode, bytes是(py2.x)的str, b 前缀代表的就是bytes
python2.x⾥, b前缀没什么具体意义,只是为了兼容python3.x的这种写法
⼩知识:
python2默认字符编码是ASCII, 当你⽤python2的解释器去运⾏你写好的py2代码(硬盘中), 解释器会⽤ASCII的编码规则去读取, 由于ACSII编码不⽀持中⽂, 所以我们⼀般在py2代码⾸⾏: #encoding: utf-8来指定字符编码规则为utf-8
python3默认的字符编码是Unicode, 当你⽤python3的解释器去执⾏你写好的py3代码(硬盘中), 解释器会⽤UTF-8编码规则来读取
例: response = b'<h1>Hello World!</h1>'    # b' ' 表⽰这是⼀个 bytes 对象
作⽤: b" "前缀表⽰:后⾯字符串是bytes 类型。
⽤处:⽹络编程中,服务器和浏览器只认bytes 类型数据。
如:send 函数的参数和 recv 函数的返回值都是 bytes 类型
附:
在 Python3 中,bytes 和 str 的互相转换⽅式是
bytes.decode('utf-8')
字符串前加 u
u/U:表⽰unicode字符串
不是仅仅是针对中⽂, 可以针对任何的字符串,代表是对字符串进⾏unicode编码。
⼀般英⽂字符在使⽤各种编码下, 基本都可以正常解析, 所以⼀般不带u;但是中⽂, 必须表明所需编码, 否则⼀旦编码转换就会出现乱码。
建议所有编码⽅式采⽤utf-8,即在py⽂件开头添加: # coding: utf-8
例:u"我是含有中⽂字符组成的字符串。"
作⽤:后⾯字符串以 Unicode 格式进⾏编码,⼀般⽤在中⽂字符串前⾯,防⽌因为源码储存格式问题,导致再次使⽤时出现乱码。
字符串前加 r
r/R:⾮转义的原始字符串
与普通字符相⽐,其他相对特殊的字符,其中可能包含转义字符,即那些,反斜杠加上对应字母,表⽰对应的特殊含义的,⽐如最常见的”\n”表⽰换⾏,”\t”表⽰Tab等。⽽如果是以r开头,那么说明后⾯的字符,都是普通的字符了,即如果是“\n”那么表⽰⼀个反斜杠字符,⼀个字母n,⽽不是表⽰换⾏了。
以r开头的字符,常⽤于正则表达式,对应着re模块。
例:r"\n\n\n\n”  # 表⽰⼀个普通⽣字符串 \n\n\n\n,⽽不表⽰换⾏了。
作⽤:去掉反斜杠的转移机制。
(特殊字符:即那些,反斜杠加上对应字母,表⽰对应的特殊含义的,⽐如最常见的”\n”表⽰换⾏,”\t”表⽰Tab等。)
应⽤:常⽤于正则表达式,对应着re模块。
python货币转换

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。