三元运算
如果这个条件成立就存这个值,如果那个条件成立就存那个值。
进制
bytes类型,字节数据类型也就是二进制类型,这个是python3专有数据类型,在python2里跟字符串是一个类型,也就是python2是不区分这个数据类型的。
比如说音频,视频文件都是二进制类型,也就是bytes类型。(python3通过socket在网络上传输数据时必须要用二进制格式,python2没有强制必须是二进制,字符串也可以)
Python3中最大的新特性就是对文本和二进制数据做了更清晰的区分。文本通常是Unicode字符集,并且用str字符串类型表示,而二进制数据用bytes字节类型表示。在Python3中,字符串str和字节bytes是不可以混合使用的,这也使得二者之间更以区分。你不能将字符串和字节连接起来,不能在字符串中得到字节,也不能在字节中得到字符串,也不能通过函数传参字符串以期望得到字节,反之亦然。
字符串和字节间是由区别的,下面的关系应该牢记在心:
字符串可被编码为字节,字节可被解码为字符串
可以这样考虑,字符串是文本的一种抽象表示。一个字符串有很多字符组成,字符是与任何特定二进制表示无关的抽象实体。处理字符串时,可以对其进行分割、切片、连接、搜索操作。我们不关心字符串在内部是如何被表示的,也不关心它用几个字节来表示每个字符。只有在将字符串编码成字节(如用于通信信道的传输)或将字节解码成字符串时,才考虑这些问题。
编码可以将抽象字符以二进制数据的形式表示,有很多编码方法,如utf-8。编码是传输过程中非常重要的一部分,没有编码,字节对象只是一簇二进制位。是编码让位有意义。对位进行不同编码可获得不同结果。
string 通过encode 编码成 bytes 类型,而bytes格式的数据又可以通过decode来解码成str类型。
encode 用来对string格式个数据进行编码:
str = ‘你好‘ str.encode(‘UTF-8‘) -->表示源数据是什么格式的,为UTF-8,非常重要一定要填写!!!虽然默认为utf-8,请一定要填写!python2默认使用系统的编码acsii b‘\xe4\xbd\xa0\xe5\xa5\xbd‘
decode 用来对bytes格式的数据进行解码:
str = b‘\xe4\xbd\xa0\xe5\xa5\xbd‘ str.decode(‘UTF-8‘) -->表示把二进制数据解释成 什么格式的数据(默认UTF-8),非常重要一定要填写!!!
str.encode("UTF-8")
str.encode(encoding=‘UTF-8‘)
str.decode("UTF-8")
str.decode(encoding=‘UTF-8‘)
这两个编码的写法是一样的
saysay=‘我爱北京天安门‘ print(saysay) print(saysay.encode(encoding=‘utf-8‘)) print(saysay.encode(encoding=‘utf-8‘).decode(encoding=‘utf-8‘))