python提供了几个基本的数值运算操作符_Python数据类型一:数字与运算符

数字

一、数值类型

python中支持的数值类型有以下几种:

1、整型(Int) - 通常被称为是整型或整数,是正或负整数,不带小数点。Python3 整型是没有限制大小的,可以当作 Long 类型使用,所以 Python3 没有 Python2 的 Long 类型。

#!/usr/bin/python#10进制

print(12345000000000000000000000000000000000000000000000000000000000000000000000000000000000);#16进制

print(0x1232423435646576879796)#8进制

print(0o123456134563163564)#2进制

print(0b10101010010011111)#结果如下,发现在print后,所有整数都被处理为了10进制数:

12345000000000000000000000000000000000000000000000000000000000000000000000000000000000

21998004324339122916792214

2941068610692980

87199

注意16进制、8进制、2进制的默认类型,并不是想象中的16进制、8进制、2进制的类型,而是"int"类型,而使用hex、oct、bin函数转化后同样不是相应类型,而是str类型,

因此可以推测,python内部对于16、8、2进制都是按照字符串来存储的,计算时再统一转化为10进制:

1 print(type(0x10))2 print(type(10))3 print(type(0o7))4 print(type(0b10))5 print(type(hex(0x10)))6 print(type(oct(0x7)))7 print(type(bin(0xb1)))

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

1 #注意浮点型数据,只能是整数表示,不能是浮点数:

2 print(0x1.0)3 print(0o4.0)4 print(0b0.1)5

6 #第一个print报错:

7 File "/usercode/file.py", line 4

8 print(0x1.0)9 ^

10 SyntaxError: invalid syntax11

12 #第二个print报错:

13 File "/usercode/file.py", line 3

14 print(0o4.0)15 ^

16 SyntaxError: invalid syntax17

18 #第三个print报错:

19 File "/usercode/file.py", line 4

20 print(0b0.1)21 ^

22 SyntaxError: invalid syntax

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

总结如下:

intfloatcomplex

10

0.0

3.14j

100

15.20

45.j

-786

-21.9

9.322e-36j

080

32.3+e18

.876j

-0490

-90.

-.6545+0J

-0x260

-32.54e100

3e+26J

0x69

70.2-E12

4.53e-7j

4、强制数字类型转换:

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

float(x)将x转换到一个浮点数。-----只能接受一个参数,仅仅能转化为小数点后1位的浮点数

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

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

1 #!/usr/bin/python

2 #10进制

3 print(int(105.021561030000))4 print(float(12345674864561))5 print(complex(5))6 print(complex(5.00))7 print(complex(5e+6j))8 #不能转化复数到int和float型数据

9 print(int(5e+6j))10 print(float(5e+6j))11

12

13 #结果如下

14 105

15 12345674864561.0

16 (5+0j)17 (5+0j)18 5000000j

19

20 #可以看到结果中,不能将复数转化为int和float型

21 Traceback (most recent call last): File "/usercode/file3.py", line 9, in print(int(5e+6j)) TypeError: can't convert complex to int

22 Traceback (most recent call last): File "/usercode/file3.py", line 10, in print(float(5e+6j)) TypeError: can't convert complex to float

5、进制数转换

1 #将其它进制数数转换为16进制:

2 >>> hex(16)3 0x10

4 >>>hex(0o7)5 0x7

6 >>>hex(0b1)7 0x1

8

9 #将其它进制数转换为10进制:

10 >>> int(0x10)11 16

12 >>>int(0o7)13 7

14 >>>int(0b1)15 1

16

17 #将其它进制数转换为8进制:

18 >>> oct(0x10)19 0o2020 >>> oct(10)21 0o1222 >>>oct(0b1)23 0o124

25 #将其它进制数转换为2进制:

26 >>> bin(0x10)27 0b1000028 >>> bin(10)29 0b101030 >>>bin(0o7)31 0b111

运算符

一、算数运算符

1、加法

1 1 + 2 //直接输入,回车直接输出结果2 3

3 >>> sum = 1 + 2 //计算结果保存在sum中4 >>> print(sum) //输出sum5 3

6 >>> a = 1 //变量7 >>> b = 2

8 >>> sum = a + b //变量相加9 >>> print(sum)10 3

2、减法

1 >>> a = 1

2 >>> b = 2

3 >>> 2 - 1

4 1

5 >>> a -b6 -1

7 >>> b -a8 1

3、乘法

1 >>> 1 * 2

2 2

3 >>> 1.5 * 3

4 4.5

5 >>> a *b6 2

7 >>>

4、除法

1 #以下代码在python3中表现如此,在python2中是以整除进行的,除不尽时小数点后默认保留16位

2 >>> 1 / 3

3 0.3333333333333333

4 >>> 5 / 2

5 2.5

6 >>> 1.0 / 3

7 0.3333333333333333

8 >>> 5.0 / 2.0

9 2.5

10

11 # 特殊点,注意看,在python3中,默认整数相除,其结果也是浮点数,这个就与传统的整数相除得整数得结论有点相悖了,在python2的基础上修改的用力过猛了:

12 >>> 4/2

13 2.0

5、整除

1 >>> 1 // 3

2 03 >>> 5 // 2

4 2

5 >>> 1.0 // 3

6 0.0

7 >>> 5.0 // 2.0

8 2.0

9

10 #当使用整除时,整数相除的结果也是整数了:

11 >>> 4//2

12 2

6、取余

1 >>> 1 % 3

2 1

3 >>> 5 % 2

4 1

5 >>> 5.0 % 2.0

6 1.0

7、幂运算

1 >>> 2 ** 3

2 8

3 >>> 2.5 ** 5

4 97.65625

5 #负数幂实际是1/4**

6 >>> 4 ** -1

7 0.25

二、比较运算符

以下假设变量a为10,变量b为20:

运算符描述实例

==

等于 - 比较对象是否相等

(a == b) 返回 False。

!=

不等于 - 比较两个对象是否不相等

(a != b) 返回 true.

>

大于 - 返回x是否大于y

(a > b) 返回 False。

<

小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。注意,这些变量名的大写。

(a < b) 返回 true。

>=

大于等于 - 返回x是否大于等于y。

(a >= b) 返回 False。

<=

小于等于 - 返回x是否小于等于y。

(a <= b) 返回 true。

1 #==和!=运算符在比较时,等式两端的值不必是同一类,如:

2 >>> a,b = "1",1

3 >>> print(a ==b)4 False5

6 >>> print(a !=b)7 True8

9 #但是其它的比较运算符,等式两端必须是同一类型值,否则会有报错:

10 >>> print(a <=b)11 Traceback (most recent call last):12 File "/usercode/file.py", line 4, in

13 print(a <=b)14 TypeError: unorderable types: str() <= int()

三、赋值运算符

以下假设变量a为10,变量b为20:

运算符描述实例

=

简单的赋值运算符

c = a + b 将 a + b 的运算结果赋值为 c

+=

加法赋值运算符

c += a 等效于 c = c + a

-=

减法赋值运算符

c -= a 等效于 c = c - a

*=

乘法赋值运算符

c *= a 等效于 c = c * a

/=

除法赋值运算符

c /= a 等效于 c = c / a

%=

取模赋值运算符

c %= a 等效于 c = c % a

**=

幂赋值运算符

c **= a 等效于 c = c ** a

//=

取整除赋值运算符

c //= a 等效于 c = c // a

四、位运算符

下表中变量 a 为 60,b 为 13。

运算符描述实例

&

按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0

(a & b) 输出结果 12 ,二进制解释: 0000 1100

|

按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。

(a | b) 输出结果 61 ,二进制解释: 0011 1101

^

按位异或运算符:当两对应的二进位相异时,结果为1

(a ^ b) 输出结果 49 ,二进制解释: 0011 0001

~

按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1

(~a ) 输出结果 -61 ,二进制解释: 1100 0011, 在一个有符号二进制数的补码形式。

<<

左移动运算符:运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。

a << 2 输出结果 240 ,二进制解释: 1111 0000

>>

右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数

a >> 2 输出结果 15 ,二进制解释: 0000 1111

1 #按位与运算符,想到一个在网络界很常用的应用,使用IP地址和子网掩码相与,得到这个IP地址所在的子网,比如192.168.1.1/16,其子网广播地址为:"192.168.1.1" & "255.255.0.0",结果应该是"192.168.0.0",当然这里只是做个例子,并不能通过字符串类型进行与操作,只能是数字类:

2

3 >>> IP,Mask = [192,168,1,1],[255,255,0,0]4 >>>print(".".join(map(str[IP[0]&Mask[0],int(IP[1])&int(Mask[1]),IP[2] & Mask[2],IP[3] & Mask[3]] ) ))5

6 192.168.0.0

五、逻辑运算符

Python语言支持逻辑运算符,以下假设变量 a 为 10, b为 20:

运算符逻辑表达式描述实例

and

x and y

布尔"与" - 如果 x 为 False,x and y 返回 False,否则它返回 y 的计算值。

(a and b) 返回 20。

or

x or y

布尔"或" - 如果 x 是 True,它返回 True,否则它返回 x 的计算值。

(a or b) 返回 10。

not

not x

布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。

not(a and b) 返回 False

由于and和or运算符规则比较奇葩,因此下面举例说明一下,且最后给一个结论,不要将True、False与数值类进行与、或运算,最终结果可能不是False、True。

奇葩的and运算符:

1 #逻辑运算符中,and比较奇葩,最终结果可能不是True或者False,而是and右边的值:

2

3 #10在右边时,返回10:

4 >>> print(True and 10)5 10

6

7 #True在右边时,返回True:

8 >>> print(10 andTrue)9 True10

11 #当然False或者0不论在左边还是右边返回值都是False,这里如果左边的值是Flase类的话,则and不会再计算后边的值,这个成为短路运算符:

12 >>> print(False and 10)13 False14 >>> print(10 andFalse)15 False

奇葩的or运算符:

1 #or运算符在左边的值为非False时,返回值就只是左边的值:

2 >>> print(True or 10)3 True4 >>> print(10 orTrue)5 10

6

7 #当左边为False或0时,才会计算右边的值,且返回值和右边值相同:

8 >>> print(False or 10)9 10

10 >>> print(False or0)11 012 >>> print(False orFalse)13 False

六、成员运算符

包含了一系列的成员,包括字符串,列表或元组。

运算符描述实例

in

如果在指定的序列中找到值返回 True,否则返回 False。

x 在 y 序列中 , 如果 x 在 y 序列中返回 True。

not in

如果在指定的序列中没有找到值返回 True,否则返回 False。

x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。

1 #在字符串中取成员

2 >>> strA = "abcd"

3 >>> print("a" instrA)4 True5

6 >>> print("e" instrA)7 False8

9

10 #在列表中取成员

11 >>> listA = [1,2,3,4]12 >>> print(1 inlistA)13 True14

15 >>> print(5 inlistA)16 False17

18 #在元组中取成员

19 >>> tupleA = (1,2,3,4)20 >>> print(1 intupleA)21 True22 >>> print(5 intupleA)23 False24

25 #字典中取成员

26 >>> dictA = {"a":1,"b":2}27 >>> print("a" indictA)28 True29

30

31 #以上取成员运算都是基于静态数据,如果成员本身是动态呢?也是可以的:

32

33 >>> listB = ([1,2,3],("a","b"),{"c":4},5)34 >>> print([1,2,3] inlistB)35 True36

37 >>> print(("a","b") inlistB)38 True39

40 >>> print( {"c":4} inlistB )41 True42

43

44 #上面动态数据只是一层嵌套,我们再次多层嵌套,同样可以的,只不过动态结构内部的结构是不会被当做成员的,但是它是成员的内部成员:

45 >>> listC = [[1,2,3,[4,5]],{"c":6,"b":[7,8,9]}]46 >>> print( [1,2,3,[4,5]] inlistC )47 True48

49 >>> print( [4,5] inlistC )50 False51

52 >>> print( [4,5] inlistC[0] )53 True54

55 >>> print( {"c":6,"b":[7,8,9]} inlistC )56 True57

58 >>> print("b" inlistC )59 False60

61 >>> print("b" in listC[1] )62 True

七、身份运算符:等同于用id()函数作用

身份运算符用于比较两个对象的存储单元

运算符描述实例

is

is是判断两个标识符是不是引用自一个对象

x is y, 如果 id(x) 等于 id(y) , is 返回结果 1

is not

is not是判断两个标识符是不是引用自不同对象

x is not y, 如果 id(x) 不等于 id(y). is not 返回结果 1

1 #数字、字符串、元组等不可变的数据类型,由于都是静态存储,因此同一个变量存储在内存中的位置都是相同的,用is运算符会返回True:

2

3 >>> a,b = 1,1

4 >>> print(a isb)5 True6

7 >>> a,b = "c","c"

8 >>> print(a isb)9 True10

11 >>> a,b = "c","c"

12 >>> print(a isb)13 True14

15 #列表等可变序列的数据类型,即使值相等,但是is运算符会返回False:

16 >>> a,b =[],[]17 >>> print(a ==b)18 True19

20 >>> a,b =[],[]21 >>> print(a isb)22 False23

24 #可以看出两个空列表所在的内存单元不同:

25 >>> print(id(a))26 139942755666120

27 >>> print(id(b))28 139942755665736

八、运算符的优先级

以下表格列出了从最高到最低优先级的所有运算符,在有多个运算符时,最好使用()将单元括起来计算,避免混淆。

运算符描述

**

指数 (最高优先级)

~ + -

按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@)

* / % //

乘,除,取模和取整除

+ -

加法减法

>> <<

右移,左移运算符

&

位 'AND'

^ |

位运算符

<= < > >=

比较运算符

== !=

等于运算符

= %= /= //= -= += *= **=

赋值运算符

is is not

身份运算符

in not in

成员运算符

not or and

逻辑运算符

一些数学函数和方法总结

一、全局基础函数

函数返回值 ( 描述 )

返回数字的绝对值,如abs(-10) 返回 10

cmp(x, y)

如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。Python 3 已废弃 。

返回给定参数的最大值,参数可以为序列。

返回给定参数的最小值,参数可以为序列。

x**y 运算后的值。

返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。

二、math库

copycode.gif

1 # 需要在使用前先import导入math标准库

2 >>> import math

3

4 # 两个常数math.pi和math.e

5 >>> math.pi //圆周率pi

6 3.141592653589793

7 >>> math.e

8 2.718281828459045 //自然常数e

9

10 # math.ceil(),向上取整:返回最小的大于或等于x的值

11 >>> math.ceil(2)

12 2

13 >>> math.ceil(2.2)

14 3

15 >>> math.ceil(2.9)

16 3

17 >>> math.ceil(3.0)

18 3

19

20 # math.floor(),向下取整,返回最大的小于或等于x的整数。

21 >>> math.floor(2)

22 2

23 >>> math.floor(2.2)

24 2

25 >>> math.floor(2.9)

26 2

27 >>> math.floor(3.0)

28 3

29

30 # math.fabs(),绝对值

31 >>> math.fabs(1.0)

32 1.0

33 >>> math.fabs(-1.0)

34 1.0

35

36

37 # math.factorial(),计算阶乘

38 >>> math.factorial(5)

39 120

40 >>> math.factorial(4)

41 24

42 >>> math.factorial(2.1) //执行错误

43 Traceback (most recent call last):

44 File "", line 1, in

45 ValueError: factorial() only accepts integral values

46 >>>

47

48 # math.exp(x)。返回e ** x。

49 >>> math.exp(2)

50 7.38905609893065

51 >>> math.e ** 2

52 7.3890560989306495 //请忽略后面的不一致,计算机浮点数本身的问题

53

54

55 *****以下运算中默认精确到1位小数点,及时本应该是整数的*****

56 # math.log(x [,base])。求以base为底的对数。

57 >>> math.log(math.e) //值传一个参数,默认以math.e为底

58 1.0

59 >>> math.log(math.e ** 2)

60 2.0

61 >>> math.log(8, 2) //两个参数,2为底

62 3.0

63 >>> math.log(100, 10) //两个参数,10为底s

64 2.0

65

66 # math.pow(x, y)。幂运算,计算xy,相当于x ** y--精度不同。

67 >>> math.pow(2, 3)

68 8.0

69 >>> 2 ** 3

70 8

71

72 # math.sqrt(x)**。求x的平方根。

73 >>> math.sqrt(4)

74 2.0

75 >>> math.sqrt(4.0)

76 2.0

77 >>> math.sqrt(4.00)

78 2.0

79 >>> math.sqrt(9.0)

80 3.0

81

82 # 开根号。Python的math库中只有开平方根,没有立方根和n次方根,不过可以利用math.pow或者**,只需把根号变成分数。

83 >>> math.pow(4, 1.0 / 2) //平方根,相当于math.sqrt(4)

84 2.0

85 >>> 4 ** (1.0 / 2) //平方根,相当于math.sqrt(4)

86 2.0

87 >>> 8 ** (1.0 / 3) //立方根

88 2.0

89 >>> 1024 ** (1.0 / 10) //10次方根

90 2.0

91

92 ****其它的函数可以使用help(math)来查看,或者查看手册****

copycode.gif

常用的一些math库函数

1、数学常量:

math.pi : 元周率

math.e : 自然常数

2、数学计算函数:

函数返回值 ( 描述 )

返回数字的上入整数,如math.ceil(4.1) 返回 5

cmp(x, y)

如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。 Python 3 已废弃。使用 (x>y)-(x

返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045

返回数字的绝对值,如math.fabs(-10) 返回10.0

返回数字的下舍整数,如math.floor(4.9)返回 4

如math.log(math.e)返回1.0,math.log(100,10)返回2.0

返回以10为基数的x的对数,如math.log10(100)返回 2.0

返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。

x**y 运算后的值,结果带浮点。

返回数字x的平方根,数字可以为负数,返回类型为实数,如math.sqrt(4)返回 2+0j

3、三角函数

函数描述

返回x的反余弦值,以弧度形式表示

返回x的反正弦,以弧度形式表示

返回x的反正切值,以弧度表示形式

返回反正切atan(y / x),以弧度形式表示

返回x 弧度的余弦

返回欧几里德范数,sqrt(x*x + y*y)

返回x的弧度的正弦值

返回x的弧度的正切

从弧度到度角 x 的转换

从角度到弧度角 x 的转换

常用的一些random库函数

可以轻松生成一些想要的随机值,使用前先import random

从列表,元组或字符串随机项。

随机浮点数r,使得0是小于或等于r,r小于1

设置生成随机数使用整数开始值。调用任何其他随机模块函数之前调用这个函数。返回None。

随机化代替列表中的项。返回None。

随机浮点数r,大于x小于y

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值