data:image/s3,"s3://crabby-images/d5434/d54341d3071ef552cf4c86effe247f91a613301e" alt="Python从入门到项目实践(超值版)"
3.2 数字类型的操作
在3.1节中了解了数字类型包括整数类型、整数的按位运算、浮点数、复数类型和布尔类型。那么在这一节中将学习数字类型的基本操作方法。
3.2.1 内置的数值操作符
data:image/s3,"s3://crabby-images/d7446/d7446a75cb4177806ab7c564854b5a7db7374840" alt=""
在Python中,内置的操作运算符主要分为四种,分别是算术运算符、赋值运算符、逻辑运算符和关系运算符。其实例分别如下。
1. 算术运算符
算术运算符如表3-3所示。
表3-3 算术运算符
data:image/s3,"s3://crabby-images/d8121/d8121e87faeaf2459cc9f7ddaa9a4d3307f26edc" alt=""
具体使用及输出如下。
【例3-8】算术运算。
data:image/s3,"s3://crabby-images/8b94a/8b94ac8976b0084d916a1fd6fadbe255812a9f3b" alt=""
2. 赋值运算符
赋值运算符如表3-4所示。
表3-4 赋值运算符
data:image/s3,"s3://crabby-images/483ed/483edd2db871e94ef0a197ba8a28321b6b1db4db" alt=""
具体使用及输出如下。
【例3-9】赋值运算。
data:image/s3,"s3://crabby-images/8bb36/8bb36d3b526e1fd0deaf2c7d70265f277215935d" alt=""
注意:除法运算结果为浮点数,和被除数与除数的类型无关。
3. 逻辑运算符
逻辑运算符如表3-5所示。
表3-5 逻辑运算符
data:image/s3,"s3://crabby-images/e86b8/e86b82b83b36f707da624c05251d0a12876330e9" alt=""
逻辑运算主要与布尔值的判断和0、1操作有关。
【例3-10】逻辑运算。
data:image/s3,"s3://crabby-images/26390/26390aff39fb77ab187113dcabc91cfe7ff7bf0c" alt=""
4. 比较运算符
比较运算符如表3-6所示。
表3-6 比较运算符
data:image/s3,"s3://crabby-images/8595d/8595dcc2bab5ac721f5b07f0a2ef96ce3f9d033d" alt=""
【例3-11】比较运算。
data:image/s3,"s3://crabby-images/92021/920211b9aad35e5f35da6cd0e603f9c647b9cec5" alt=""
3.2.2 内置的数值运算函数
data:image/s3,"s3://crabby-images/94738/9473806397166d631773ab10a02d373423ac6820" alt=""
内置的数值运算函数如表3-7所示。
表3-7 内置的数值运算函数
data:image/s3,"s3://crabby-images/f9fb6/f9fb67bd10e86abe9b4c7e0616da0d3d9a79a1c1" alt=""
部分函数操作及其具体用法示例如下。
【例3-12】函数运算。
data:image/s3,"s3://crabby-images/bbced/bbcedae95a4e107864d3b833746a0a7674c0e039" alt=""
常见的函数操作中,部分函数的用法需要特殊记忆。下面列举的函数其用法虽然不广泛,但是对于理解Python的数据类型和存储有着较为直观的意义。
(1)函数round()与精度误差。
函数round()的作用为将浮点数A进行四舍五入,并指定小数的位数。关于舍入需要知道Python中浮点数的特征。
浮点数本身就是非精确数据。大多数十进制小数并不能完全用二进制小数来表示。因此,输入的十进制浮点数一般只能用二进制浮点数来进行近似。
例如在十进制中,对于分数1/3,将其写成小数时只能无限近似写成1.333…,同理,在面对十进制浮点小数例如0.1时,无法将其完美地换算为二进制数据,只能无限近似。Python中存在一个近似策略,用户面对的屏幕输出的十进制数值仅是被输出的一个近似值,其真实的值以二进制数值存储在机器上。上述情况告诉我们,Python以舍入形式进行数据的近似管理。
round()函数在使用上实际上也很简单。
【例3-13】round()函数。
data:image/s3,"s3://crabby-images/bd960/bd960f046b922c04fa9a8d60ac144fafc837decc" alt=""
这和人们认知中的小数近似结果一致,即四舍五入,但是有时候考虑到前面提到的存储情况时就会出现另一种状况。
【例3-14】round()函数精度。
data:image/s3,"s3://crabby-images/03c83/03c8331f9e6d81357caf56805f65fb47d865681f" alt=""
可以清楚地看到,这似乎违背了四舍五入的基本法则,实际上这是由于计算机只能采用近似储存浮点数,导致精度误差所致。官方文档存在下列说明:
data:image/s3,"s3://crabby-images/5e2c7/5e2c79a2f7e10e3285a18d6043e26f42fd165833" alt=""
可以得知数据在近似转换为0、1储存时被进行了截断处理,因此导致了精度误差,为此round()近似函数实际上只能进行对精度要求不大的近似求值。关于精确计算,Python提供了其他选择,例如后续将要学到的math模块中的ceiling方法和将要介绍的decimal模块。
(2)pow()函数的使用。
pow(x,y[,z])函数看似等价于(x**y)%z。
【例3-15】pow()函数。
data:image/s3,"s3://crabby-images/e55ac/e55ac9e9fd17f9f8911217d9cbb71e30b3b36e2e" alt=""
但是实际上,它们并不完全等价。
【例3-16】特殊pow()函数。
data:image/s3,"s3://crabby-images/a8b25/a8b25a52dcdb05fd01fc60cd2d7dab695bc63b51" alt=""
可知,Python不允许第三个操作数为浮点数,这与x**y%z存在差异,可知在使用上并不完全等价。
3.2.3 内置的数字类型转换函数
data:image/s3,"s3://crabby-images/37854/378548b412fb5d48f71b9b125267dd16d87bf6a0" alt=""
内置的数字类型转换函数如表3-8所示。
表3-8 内置的数字类型转换函数
data:image/s3,"s3://crabby-images/8a6ec/8a6ec213b92c2a29f07b570502fc7bb38a49260e" alt=""
函数使用举例如下。
【例3-17】ascii()函数。
ascii()函数类似Python 2.X中的repr()函数,结果为返回这个指定可打印对象的字符串表示,如果此对象为非ascii字符就以转义字符型输出(\x,\u等),例如中文字符串,具体实例如下。
data:image/s3,"s3://crabby-images/be886/be886d4fb54d194a22883b8af9b63dbc7f038864" alt=""
其中,函数int(x[,base])和函数float(x[,base])内的第二个参数的含义通过以下实例来解释。
【例3-18】int()函数。
data:image/s3,"s3://crabby-images/3f8d7/3f8d7f5c46b4863bf8a20a31a3ca5023ec3e486d" alt=""
通过实例可以知道,参数base的作用是指定第一个参数的进制类型。此时的x参数不可为数字,只能为字符串、数组或者将要学到的数组列表类型。
base默认为十进制,当指定为8时是八进制,为16时是十六进制等,但注意当其为0的时候,依旧表示十进制。
对于函数complex(real,[imag]),其实例如下。
【例3-19】complex()函数。
data:image/s3,"s3://crabby-images/73295/73295f3160ba87d78e2120bf435850694440147d" alt=""
可知参数real和imag也可以为计算式,如果第一个参数是一个字符串,它将被解释为一个复数,并且必须在没有第二个参数的情况下调用该函数。第二个参数不可以为字符串。每个参数可以是任何数字类型(包括复数)。如果省略imag,则默认为零,构造函数用作int和float之类的数字转换。如果省略两个参数,则返回0j。