数字类型

Posted xiaohei001

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数字类型相关的知识,希望对你有一定的参考价值。

Python数字数据类型用于储存数值。

数字类型是不可变类型,所谓不可变类型,指的是类型的值一旦有不同了,那么他就是一个全新的对象,数字1和2分别代表两个不同的对象,对变量重新赋值一个数字类型,会新创建一个数字对象。

Python的变量和数据类型的关系:变量只是对某个对象的引用或者说代号、名字、调用等等,变量本身没有数据类型的概念,类似1,[2,3,4],"1234"这一类的对象具有数据类型的概念。如:

a = 1  # 创建数字对象1
a = 2  # 创建数字对象2,并将2赋值个变量a,a不在指向数字对象1

 这里发生了变化的是变量a的指向,而不是数字对象1变成了数字对象2。

Python支持三种不同的数字类型、整数、浮点数和复数。

整型(int)

通常被称为是整型或整数,是正或复整数,不带小数点,Python整型是没有限制大小的,可以当作Long类型使用,所以Python3没有Python2的Long类型。

例如:1,100,-1,0 等。

表示数字的时候,有时我们还会用八进制或十六进制表示。

十六进制用0x前缀和0-9,a-f表示 。如:0xff00,0xa5b4c3d2。

八进制用0o前缀和0-7表示。如:0o12。

Python的整数长度为32位,并且通常是连续分配内存空间的。

print(id(1))
print(id(2))
print(id(3))

# 结果为
# 1949782816
# 1949782848
# 1949782880

上面的空间地址看,地址之间正好差32,因为Python在初始化环境的时候就在内存里自动划分了一块空间,专门用于整数对象的存取。当然,这块空间也不是无限大小的,能保存的整数是有限的,所以看到id(0)和id(10000)之间的地址差别很大

print(id(0))
print(id(10000))

# 结果为:
# 1949782816
# 1784201367440

1.小整数对象池

Python初始化的时候回自动创建一个小整数对象池,方便我们调用,避免后期重复生成,这是一个包含262个指向整数对象的指针数组,范围是 -5到256.也就是说比如整数10,即使我们在程序里没有创建它,其实在Python后台已经为我们创建了。

 为什么要这样呢?都知道在程序运行时,包含Python后台自己的运行环境,会频繁使用这一范围内的整数,如果没需要一个,就创建一个,那么无疑会增加更多的开销,创建一个一直存在,永不销毁,随用随拿的小整数对象池,是一个比较实惠的做法。

>>> a = -5
>>> b = -5
>>> a is b
True
>>> a = 256
>>> b = 256
>>> a is b
True
>>> a = 257
>>> b = 257
>>> a is b
False

2.大整数对象池

终端是每次执行一条语句,所以每次的大整数都是重新创建,而在Pycharm中,每次运行时所有代码都加在内存中,属于一个整体,所以这个时候会有一个大整数池,处于一个代码块的大整数是同一个对象。c1和d1处于一个代码块,而c1.b和c2.b分别有自己的代码块,所以不相等

>>> a = 1000
>>> b = 1000
>>> a is  b
False
>>> a = 1888
>>> a = 1888
>>> a is b
False

Pycharm工具中

c1 = 1000
d1 = 1000
print(c1 is d1)  # True


class C1(object):
    a = 100
    b = 100
    c = 1000
    d = 1000


class C2(object):
    a = 100
    b = 1000


print(C1.a is C1.b)  # True
print(C1.a is C2.a)  # True
print(C1.b is C2.b)  # False

浮点数(float)

浮点型由整数部分与小数部分组成,浮点型也可以使用科学计数法表示(2.5e2 = 2.5 x 102 = 250)。如;

1.23,3.14,-9.01,等等。但是对于很大或很小的浮点数,一般用科学计数法表示,把10用e替代,1.23x10^9就是1.23e9,或者12.3e8,0.000012可以写成1.2e-5,等等

复数((complex))

复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型。

Python支持复数,复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型。

 数字类型转换

int(x) 将x转换为一个整数。

float(x) 将x转换为一个浮点数。

complex(x)将x转换为一个复数,实数部分为x,虚数部分为0。

complex(x,y)将x和y转换为一个复数,实数部分为x,虚数部分为y,x和y是数字表达式。

如:浮点数类型 ---> 整数类型,整数类型 ---> 浮点数类型

a = 1.0
b = int(a)
print(b)  # 1
print(type(b))  # <class ‘int‘>

a = 1
b = float(a)
print(b)  # 1.0
print(type(b))  # <class ‘float‘>

数字运算

Python 解释器可以作为一个简单的计算器,您可以在解释器里输入一个表达式,它将输出表达式的值。

表达式的语法很直白: +, -, * 和 /, 和其它语言(如Pascal或C)里一样。例如:

>>> 2 + 2
4
>>> 50 - 5*6
20
>>> (50 - 5*6) / 4
5.0
>>> 8 / 5  # 总是返回一个浮点数
1.6

注意:在不同的机器上浮点运算的结果可能会不一样。

在整数除法中,除法 / 总是返回一个浮点数,如果只想得到整数的结果,丢弃可能的分数部分,可以使用运算符 // :

>>> 17 / 3  # 整数除法返回浮点型
5.666666666666667
>>>
>>> 17 // 3  # 整数除法返回向下取整后的结果
5
>>> 17 % 3  # %操作符返回除法的余数
2
>>> 5 * 3 + 2 
17

注意:// 得到的并不一定是整数类型的数,它与分母分子的数据类型有关系。

>>> 7//2
3
>>> 7.0//2
3.0
>>> 7//2.0
3.0
>>> 

等号 = 用于给变量赋值。赋值之后,除了下一个提示符,解释器不会显示任何结果。

>>> width = 20
>>> height = 5*9
>>> width * height
900

Python 可以使用 ** 操作来进行幂运算:

>>> 5 ** 2  # 5 的平方
25
>>> 2 ** 7  # 2的7次方
128

变量在使用前必须先"定义"(即赋予变量一个值),否则会出现错误:

>>> n   # 尝试访问一个未定义的变量
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name n is not defined

不同类型的数混合运算时会将整数转换为浮点数:

>>> 3 * 3.75 / 1.5
7.5
>>> 7.0 / 2
3.5

在交互模式中,最后被输出的表达式结果被赋值给变量 。例如:

>>> tax = 12.5 / 100
>>> price = 100.50
>>> price * tax
12.5625
>>> price + _
113.0625
>>> round(_, 2)
113.06

此处, 变量应被用户视为只读变量。

对于数学计算,除了前面提到的简单加减乘除等等,更多的是科学计算需要导入Math这个库,它包含了大多数我们可能需要的科学计算函数,

函数返回值 ( 描述 )
abs(x) 返回数字的绝对值,如abs(-10) 返回 10
ceil(x) 返回数字的上入整数,如math.ceil(4.1) 返回 5
exp(x) 返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045
fabs(x) 返回数字的绝对值,如math.fabs(-10) 返回10.0
floor(x) 返回数字的下舍整数,如math.floor(4.9)返回 4
log(x) 如math.log(math.e)返回1.0,math.log(100,10)返回2.0
log10(x) 返回以10为基数的x的对数,如math.log10(100)返回 2.0
max(x1, x2,...) 返回给定参数的最大值,参数可以为序列。
min(x1, x2,...) 返回给定参数的最小值,参数可以为序列。
modf(x) 返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。
pow(x, y) x**y 运算后的值。
round(x [,n]) 返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。
sqrt(x) 返回数字x的平方根
acos(x) 返回x的反余弦弧度值。
asin(x) 返回x的反正弦弧度值。
atan(x) 返回x的反正切弧度值。
atan2(y, x) 返回给定的 X 及 Y 坐标值的反正切值。
cos(x) 返回x的弧度的余弦值。
hypot(x, y) 返回欧几里德范数 sqrt(xx + yy)
sin(x) 返回的x弧度的正弦值。
tan(x) 返回x弧度的正切值。
degrees(x) 将弧度转换为角度,如degrees(math.pi/2) , 返回90.0
radians(x) 将角度转换为弧度

以及两个数学常量:

常量描述
pi 数学常量 pi(圆周率,一般以π来表示)
e 数学常量 e,e即自然常数(自然常数)。

下面是一些应用展示,注意最后的角度调用方式:

>>> math.log(2)
0.6931471805599453
>>> math.cos(30)
0.15425144988758405
>>> math.cos(60)
-0.9524129804151563
>>> math.sin(30)
-0.9880316240928618
>>> math.sin(math.degrees(30))
-0.4097717985741408
>>> math.sin(math.radians(30))
0.49999999999999994

 

以上是关于数字类型的主要内容,如果未能解决你的问题,请参考以下文章

10个JavaScript代码片段,使你更加容易前端开发。

golang代码片段(摘抄)

在代码片段中包含类型转换

Python学习总结

如何创建一个查询来查找 2 个数字之间的值,这些数字是 MongoDB 中的字符串类型

对这个带有 & 不带 = 的代码片段返回类型感到非常困惑