python数字类型
Python中有四种类型的数
整数:一般意义上的数,包含十进制(无前缀),八进制(0开头),十六进制(0x开头),二进制(0b开头)
例子, 2
长整数:无限大小的数,表示范围和内存有关
例子, 2012121200
浮点数:小数或用e/E(10的幂)表示的幂,默认,浮点数学缺乏精确性,可以使用decimal
例子, 3.23 50.2E2
复数:复数的虚部以字母J 或 j结尾
例子, 2+3i
1.分数
浮点数和分数转换:
(2.5).as_integer_ratio() #返回元组(5,2)
或者Fraction.from_float(1.75)
2.复数
a = 实数 + 虚数j
a.real #实部
a.imag #虚部
a.conjugate() #共轭复数
虚数不能单独存在, 总是和一个值为0.0的实数部分一起构成一个复数
实数部分和虚数部分都是浮点数
运算符
+加法
-减法
*乘法
**幂次(也可以使用内建的pow()函数来进行幂运算)
/除法(2.x中是整除,3.x是浮点除)
//取整,商的整数部分强制整除(浮点数也会做整除运算)
%取余(可以使用内建的divmod()函数获得结果和余数的元组)
&位与
|位或
^位异或
~位翻转 x -> -(x+1)
<<左移
>>右移
值不相等 a != b
运算符优先级,同级从左到右
BP:良好的做法是随时根据优先级需要加入括号,而不是依赖默认优先级
python内置函数
最常用round
1.abs(number)
返回数字的绝对值,
如果是复数, 返回math.sqrt(num.real2 + num.imag2)
2.coerce(number1, number2)
按照类型转换规则,将num1和num2转为同一类型,以元组形式返回
3.divmod(number1, number2)
返回一个包含商和余数的元组
整数返回地板除和取余操作结果
浮点数返回的商部分是math.floor(number1/number2)
复数的商部分是ath.floor((number1/number2).real)
4.pow(num1,num2,mod=1)
同**操作符
第三个为可选参数,即一个余数操作,若存在这个参数,先指数,后与第三个参数取余,性能比pow(x,y)%z更高
5.round(number[, base])
对浮点数进行四舍五入运算,base参数是小数位参数,决定了精确到小数点后几位
6.其他
其他内建及工厂函数在后面类型转换和进制转换中说明
类型转换
转换工厂函数主要在类型转换和进制转换中用到
int(str, base=10) 转换为整型数,base为相应的进制;base的范围是2~32,base缺省十进制
long(obj,base=10), 转长整型
float(obj),转浮点数
complex(str),complex(real, imag=0.0), 转复数
bool(obj) 返回obj对象的布尔值,即obj.__nonzero__()方法返回值,没有__nonzero__()方法的对象默认值是True
string(),转字符串
chr(num) ASCII数字值转为字符
ord(chr) 字符转对应ASCII/Unicode值
unichr(num) 接收Unicode码值
进制转换
八进制:0o1
十六进制:0x10
二进制0b1
1.十进制到其他
oct(64) #->8
hex(64) #->16
bin(64) #->2
接收一个整型对象(任意进制),返回对应值的字符串
2.其他到十进制
其他
1.小整数缓存
看python源代码可知,下限-5,上限256被设定为缓存范围。
2.除法关于传统除法/真正除法/地板除传统除法
>>> 1/2
0
>>> 1.0/2.0
0.5
真正除法
>>> from __future__ import division
>>> 1/2
0.5
>>> 1.0/2.0
0.5
地板除
>>> 1//2
0
>>> 1.0//2.0
0.0
>>> -1//2
-1
常用模块:
python math模块
python random模块
python decimal模块
operator