Python基础:数值(布尔型、整型、长整型、浮点型、复数)
一、概述
Python中的 数值类型(Numeric Types)共有5种:布尔型(bool)、整型(int)、长整型(long)、浮点型(float)和复数(complex)。
数值类型支持的主要操作如下:
操作 | 说明 | bool | int | long | float | complex |
---|---|---|---|---|---|---|
x ** y | 指数运算 | √ | √ | √ | √ | √ |
+x | 符号不变 | √ | √ | √ | √ | √ |
-x | 符号取反 | √ | √ | √ | √ | √ |
~x | 按位取反 | √ | √ | √ | ||
x * y | 乘法 | √ | √ | √ | √ | √ |
x / y | 除法 | √ | √ | √ | √ | √ |
x // y | 地板除 | √ | √ | √ | √ | √ |
x % y | 取余 | √ | √ | √ | √ | √ |
x + y | 加法 | √ | √ | √ | √ | √ |
x - y | 减法 | √ | √ | √ | √ | √ |
x << y | 位左移 | √ | √ | √ | ||
x >> y | 位右移 | √ | √ | √ | ||
x & y | 按位与 | √ | √ | √ | ||
x ^ y | 按位异或 | √ | √ | √ | ||
x | y | 按位或 | √ | √ | √ | ||
abs(x) | 取绝对值 | √ | √ | √ | √ | √ |
bin(x) | 整型->二进制字符串 | √ | √ | √ | ||
bool(x) | 布尔型转换 | √ | √ | √ | √ | √ |
chr(x) | ASCII码->单字符串 | √ | √ | √ | ||
complex(re, im) | 实部为re,虚部为im的复数 | √ | √ | √ | √ | √ |
divmod(x, y) | 除法及取余 | √ | √ | √ | √ | √ |
float(x) | 浮点转换函数 | √ | √ | √ | √ | |
hex(x) | 整型->十六进制字符串 | √ | √ | √ | ||
int(x) | 整型转换 | √ | √ | √ | √ | |
long(x) | 长整型转换 | √ | √ | √ | √ | |
pow(x) | 指数运算 | √ | √ | √ | √ | √ |
oct(x) | 整型->八进制字符串 | √ | √ | √ | ||
round(x[, n]) | 保留n位小数并四舍五入 | √ | √ | √ | √ | |
unichr(x) | ASCII码->Unicode单字符串 | √ | √ | √ |
二、布尔型
布尔型 其实是整型的子类型,布尔型数据只有两个取值:True和False,分别对应整型的1和0。
每一个Python对象都天生具有布尔值(True或False),进而可用于布尔测试(如用在if、while中)。
以下对象的布尔值都是False:
- None
- False(布尔型)
- 0(整型0)
- 0L(长整型0)
- 0.0(浮点型0)
- 0.0+0.0j(复数0)
- ''(空字符串)
- [](空列表)
- ()(空元组)
- {}(空字典)
- 用户自定义的 类实例,该类定义了方法
__nonzero__()
或__len__()
,并且这些方法返回0或False
除开上述对象之外的所有其他对象的布尔值都为True。
# 1. Python对象的布尔值
>>> bool(None)
False
>>> bool(False), bool(0), bool(0L), bool(0.0), bool(0.0+0.0j)
(False, False, False, False, False)
>>> bool(''), bool([]), bool(()), bool({})
(False, False, False, False)
>>>
>>> class A: pass
...
>>> class B:
... def __len__(self):
... return 0
...
>>> class C:
... def __nonzero__(self):
... return False
...
>>> bool(A), bool(A())
(True, True)
>>> bool(B), bool(B())
(True, False)
>>> bool(C), bool(C())
(True, False)
# 2. 数值运算中,布尔值True和False分别对应整型的1和0
>>> int(True), int(2 < 1)
(1, 0)
>>> (False + 100) / 2 - (True // 2)
50
>>> print '%s, %d' % (bool('0'), False)
True, 0
三、整型
整型 等价于C中的有符号长整型(long),与系统的最大整型一致(如32位机器上的整型是32位,64位机器上的整型是64位),可以表示的整数范围在[-sys.maxint-1, sys.maxint]之间。整型字面值的表示方法有3种:十进制(常用)、八进制(以数字“0”开头)和十六进制(以“0x”或“0X”开头)。
整型的操作示例如下:
# 1. 传统除、真正除与地板除
>>> 1 / 2 # 传统除
0
>>> 1 // 2 # 地板除
0
>>> from __future__ import division
>>> 1 / 2 # 真正除
0.5
>>> 1 // 2 # 地板除
0
# 2. 商、余数与指数
>>> 10 // 3, 10 % 3, divmod(10, 3)
(3, 1, (3, 1))
>>> 2 ** 5, pow(2, 5)
(32, 32)
>>> -2 ** 3 # 等效于:-(2 ** 3)
-8
>>> 2 ** -3 # 等效于:2 ** (-3) 即 1.0 / (2 ** 3)
0.125
# 3. 进制转换
>>> bin(20), oct(20), hex(20)
('0b10100', '024', '0x14')
四、长整型
长整型 是整型的超集,可以表示无限大的整数(实际上只受限于机器的虚拟内存大小)。长整型字面值的后面带有字母“L”或“l”(推荐使用大写的“L”)。
长整型与整型的操作完全相同,简单示例如下:
>>> 999 ** 8 # 整型自动转换为长整型
992027944069944027992001L
>>> 10L // 3L, 10L % 3L, divmod(10L, 3L)
(3L, 1L, (3L, 1L))
>>> 2L ** 5L, pow(2L, 5L)
(32L, 32L)
五、浮点型
浮点型 类似于C中的双精度浮点型(double),其精度信息和内部表示可以从sys.float_info中获得。浮点型字面值可以用十进制或科学计数法表示,在科学计数法中,e或E代表10,+(可以省略)或 - 表示指数的正负。
浮点数的操作示例如下:
>>> 1.0 / 1e-2
100.0
>>> 2.0 ** 5.0 // 7
4.0
>>> round(3.1415926, 4)
3.1416
>>> round(-3.1415926, 4)
-3.1416
六、复数
复数 与数学中的复数概念完全相同。Python中的复数有以下几个特性:
- 复数由实数部分和虚数部分构成,表示为:real+imagj 或 real+imagJ
- 复数的实部real和虚部imag都是浮点型
复数的操作示例如下:
>>> c = -8.333-1.47j
>>> c
(-8.333-1.47j)
>>> c.real # 实部
-8.333
>>> c.imag # 虚部
-1.47
>>> c.conjugate() # 共轭复数
(-8.333+1.47j)
>>>
>>> abs(c) # 绝对值
8.461665852537548
>>> import math
>>> math.sqrt(c.real ** 2 + c.imag ** 2) # 等价于abs(c)
8.461665852537548
七、类型转换
1、强制类型转换(工厂函数)
>>> bool(5.0)
True
>>> int(5.0)
5
>>> long(5.0)
5L
>>> float(5)
5.0
>>> complex(1, 2.5)
(1+2.5j)
2、自动类型转换与coerce()
如果参与运算的两个操作数的类型不同,则Python会按照以下规则进行自动类型转换:
- 如果有一个操作数是复数,另一个操作数被转换为复数
- 否则,如果有一个操作数是浮点型,另一个操作数被转换为浮点型
- 否则,如果有一个操作数是长整型,另一个操作数被转换为长整型
- 否则,两者必然都是整型,无须类型转换
上述转换规则总结起来就是:非复数转复数,非浮点型转浮点型,非长整型转长整型,整型不变。实际的转换示例如下:
>>> >>> 1.0 + (5+2j) # 非复数转复数
(6+2j)
>>> 4L + 6.0 # 非浮点型转浮点型
10.0
>>> 4 + 6L # 非长整型转长整型
10L
>>> 4 + 6 # 整型不变
10
coerce(x, y)是一个内建函数,它按照上述转换规则对x和y进行类型转换,并返回由转换后的x和y构成的一个元组。使用示例如下:
>>> coerce(1.0, 5+2j) # 非复数转复数
((1+0j), (5+2j))
>>> coerce(4L, 6.0) # 非浮点型转浮点型
(4.0, 6.0)
>>> coerce(4, 6L) # 非长整型转长整型
(4L, 6L)
>>> coerce(4, 6) # 整型不变
(4, 6)
八、相关模块
Python标准库中与数值类型相关的核心模块有(更多模块参考 Numeric and Mathematical Modules):
模块 | 说明 |
---|---|
decimal | 十进制浮点运算类Decimal |
array | 高效数值数组(字符、整型、浮点型等) |
math / cmath | 标准C库数学运算函数。常规运算在math模块,复数运算在cmath模块 |
operator | 数值操作符的函数实现。如operator.add等价于+,operator.sub等价于- |
random | 多种伪随机数生成器 |
对于高级的数值科学计算,可以关注第三方包 NumPy 和 SciPy,《用Python做科学计算》(在线 | 下载)是关于这一主题的非常好的参考书籍。
Python基础:数值(布尔型、整型、长整型、浮点型、复数)的更多相关文章
- python基础--数值类型和序列类型
Python中数值类型:int(整数),float(浮点数),True/False(布尔值,首字母必须大写) int:1 #任意整数 float:2.3 #小数 python赋值: a = ...
- python基础语法5 函数定义,可变长参数
函数 1.什么是函数 函数就是一种工具. 可以重复调用 2.为什么要用函数 1.防止代码冗(rong)余 2.代码的可读性差 3.怎么用函数 1.定义函数-->制造工具 2.调用函数--> ...
- Python基础语法——(引号、字符串、长字符串、原始字符串、Unicode)
一.单引号字符串和转义引号 当字符串中出现单引号'时,我们可以用双引号""将该字符串引起来:"Let's go!" 而当字符串中出现双引号时,我们可以用单引号' ...
- Python基础——数值
运算 运算 运算符 示例 加 + 减 - 乘 * 除 / 取余 % 幂 ** 赋值 = 绝对值 abs 取整(四舍五入) round 最大值 max 最小值 min 科学计数法 e 十六进制 0x 逻 ...
- Python基础-求两个字符串最长公共前轴
最长公共前缀,输入两个字符串,如果存在公共前缀,求出最长的前缀,如果没有输出no.如“distance”和“discuss”的最长公共前缀是“dis”. s1 = input('请输入第1个字符串-- ...
- 2015/8/29 Python基础(3):数值
数字提供了标量储存和直接访问,是不可更改类型,每次变更数值会产生新的对象.Python支持多种数字类型,包括整型.长整型.布尔型.双精度浮点.十进制浮点和复数.在Python中,变量并不是一个盒子,而 ...
- 005 Python的数值类型
005 Python的数值类型 BIF 指的是内置函数,一般不作为变量命名.如 input,while,if,else,float,等等.整型:整数.(python3.0版本把整型和长整型结合在 ...
- python基础整理1
基础知识 名字与对象,类与类型 变量:在Python中,存储一个数据,需要一个叫做变量的东西 num2 = 87 #num2是一个变量 变量的类型: 程序中为了更充分的利用内存空间以及更有效率的管 ...
- Python 基础总结篇
变量及数据类型 Numbers数字分为:int整型,long长整型,float浮点型,complex复数 String字符串由数字.字母.下划线组成的一串字符,用于表示文本的数据类型 bool布尔型: ...
随机推荐
- embarcadero radstudio xe5 正式版 下载地址
http://altd.embarcadero.com/download/radstudio/xe5/delphicbuilder_xe5_win.iso
- MySQL – 导出数据成csv
方案有很多种,我这里简单说一下: 1. into outfile SELECT * FROM mytable INTO OUTFILE '/tmp/mytable.csv' FIELDS TERMI ...
- Openvswitch原理与代码分析(6):用户态流表flow table的操作
当内核无法查找到流表项的时候,则会通过upcall来调用用户态ovs-vswtichd中的flow table. 会调用ofproto-dpif-upcall.c中的udpif_upcall_hand ...
- 2015 Android Dev Summit(安卓开发峰会)第一天
今年的Google I/O没有抽到票,不能到现场参加.不过11月举行的Android Dev Summit的票是先到先得的方式,所以早早的提交了注册.今天终于有机会当面跟Android系统的设计开发者 ...
- Oracle数据库管理员面试题
Oracle数据库管理员面试题 1.模拟使用oracle的flashback找回过去某个时间点的数据,实现误操作的恢复. http://www.txw100.com/soft/2013/08/547. ...
- 百度地图api根据定位获取附近商家(只获取屏幕内)
根据中心点坐标计算出屏幕2个点(一个最低经纬度,一个最高经纬度),判断这两个点中间的所有坐标的商家..考虑屏幕分辨率之类 移动地图中心点变动,如何异步刷新,判断商家是否已经存在..等... 百度地图a ...
- mysql 索引- 笔记
索引 mysql最常用的索引结构是btree(O(log(n))),但是总有一些情况下我们为了更好的性能希望能使用别的类型的索引.hash就是其中一种选择,例如我们在通过用户名检索用户id的时候,他们 ...
- 转:C#中String类的几个方法(IndexOf、LastIndexOf、Substring)
String.IndexOf String.IndexOf 方法 (Char, Int32, Int32)报告指定字符在此实例中的第一个匹配项的索引.搜索从指定字符位置开始,并检查指定数量的字符位置. ...
- Bower 手册
安装 Bower 使用 npm 安装 Bower.(Bower 依赖于 Node, npm 和 Git.) $ npm install -g bower 基本用法 安装程序包 程序包安装命令 bowe ...
- (转)linux文件读写的流程
转自http://hi.baidu.com/_kouu/item/4e9db87580328244ef1e53d0 在<linux内核虚拟文件系统浅析>这篇文章中,我们看到文件是如何被打开 ...