一、基本概念

1、Python语言支持的运算符类型

  算数运算符、比较运算符、赋值运算符、逻辑运算符、位运算符、成员运算符、身份运算符、运算符优先级

2、计算顺序  

  运算符优先级表决定了哪个运算符在别的运算符之前计算,若是要改变计算的顺序,使用圆括号。

3、结合规律

  运算符通常由左向右结合,即相同优先级的运算符按照从左向右的顺序计算。

In [2]: 3*4-2+6/2Out[2]: 13In [3]: 3*4-(2+6)/2Out[3]: 8

 

二、运算符优先级表

运算符 描述
lambda lambda表达式
or 布尔“或”
and 布尔“与”
not x 布尔“非”
in,not in 成员测试
is,is not 同一性测试
<,<=,>,>=,!=,== 比较
| 按位或
^ 按位异或
& 按位与
>>,<< 移位
+,- 加法与减法
*,/,% 乘法、除法、取余
+x,-x 正负号
~x 按位翻转
** 指数
x.attribute 属性参考
x[index] 下标
x[index:index] 寻址段
f(arguments...) 函数调用
(expression,...) 绑定或元组显示
[expression,...] 列表显示
{key:datum,...} 字典显示
'expression,...' 字符串转换

 

三、运算符相关函数

1、内建函数

cmp():比较两个数的大小

type():返回数字对象的类型

str():将数字转换为字符串

int():将变量的值的类型转换为整型的

In [4]: cmp(5,6)
Out[4]: -1In [5]: cmp(6,6)
Out[5]: 0

In [6]: cmp(9,6)
Out[6]: 1

解析:cmp()是将圆括号里的第一个数和第二数进行比较,<(输出-1)、=(输出0)、>(输出1)

In [8]: str(123)
Out[8]: '123'In [9]: str(0xFF)
Out[9]: '255'In [10]: type(123666666666666666666666666)
Out[10]: long

In [12]: a=456In [13]: type(a)
Out[13]: int

In [14]: str(a)
Out[14]: '456'

2、数值工厂函数

int():返回一个字符串或者数值对象的整型表示

long():返回一个字符串或者数值对象的长整型表示

float():返回一个字符串或者数值对象的浮点型表示

bool():返回对象的布尔值

In [17]: int(3.1415926)
Out[17]: 3In [18]: long(56)
Out[18]: 56LIn [19]: float(8)
Out[19]: 8.0In [20]: bool(0)
Out[20]: False

In [21]: bool(1)
Out[21]: True

In [22]: bool(123)
Out[22]: True

3、功能函数

abs():返回给定参数的绝对值

coerce():返回一个包含类型转换完毕的两个数值元素的元组

divmod():将除法和取余运算结合起来,返回一个包含商和余数的元组

pow():可以进行指数运算

round():用于对浮点型进行四舍五入运算

In [24]: abs(-123)    #|-123|=123Out[24]: 123In [25]: coerce(12,23)
Out[25]: (12, 23)

In [26]: divmod(10,3)    #10除以3等于3余1Out[26]: (3, 1)

In [27]: pow(2,3)    #2^3=8Out[27]: 8In [28]: round(3.1415926)
Out[28]: 3.0In [29]: round(5.678)
Out[29]: 6.0

4、数字进制转换函数

hex():将数字转换成十六进制数并以字符串形式返回

oct():将数字转换成八进制数并以字符串形式返回

bin():将数字转换成二进制数并以字符串形式返回

In [30]: hex(123)
Out[30]: '0x7b'In [31]: oct(9)
Out[31]: '011'In [32]: bin(9)
Out[32]: '0b1001'

注意:

  1、Python中进制显示

    二进制binary--0b

    八进制octal--0

    十进制decimal

    十六进制hex--0x

  2、在shell中 0开头的数认为是八进制的数

[root@localhost ~]# echo $((08*2))-bash: 08: value too great for base (error token is "08")
[root@studying ~]# echo $((07*2))14[root@localhost ~]# echo $((09*2))-bash: 09: value too great for base (error token is "09")

解析:在shell中0开头的数被解释为八进制的数值(八进制数个位最大是7)

[root@localhost ~]# echo $((9*2))18[root@localhost ~]# echo $((10#09*2))18

解决办法:在数值的前面注释10#表示该数为十进制数

 

四、脚本实例之运算符

脚本练习1:分数成绩的判断

#!/usr/bin/pythonu_grade=raw_input("please input your grade:")if u_grade.isdigit():    if 90<=int(u_grade)<=100:        print "your grade is",u_grade,"A"
    elif 80<=int(u_grade)<=89:        print "your grade is",u_grade,"B"
    elif 70<=int(u_grade)<=79:        print "your grade is",u_grade,"C"
    elif 60<=int(u_grade)<=69:        print "your grade is",u_grade,"D"
    elif 0<=int(u_grade)<=59:        print "your grade is",u_grade,"E"
    else:        print "please input the range of number 0-100"else:    print "It's not a valid number,try again"

脚本练习2:用户信息的按条件获取

#!/usr/bin/pythonimport os

f=os.popen('cat /etc/passwd')for i in f:
    u_list=i.split(":")    if 500 
  

脚本练习3:加、减、乘、除、取余运算

#!/usr/bin/python#coding=utf-8num1=raw_input("please input the first number:x=")
num2=raw_input("请输入第二个数字:y=")#优化方向:进行数值的大小判断,合理运算if num1.isdigit() and num2.isdigit():    print "x*y=",int(num1)*int(num2)    print "x+y=",int(num1)+int(num2)    print "x-y=",int(num1)-int(num2)    print "x/y=",int(num1)/int(num2)    print "x%y=",int(num1)%int(num2)else:    print "please input two number"

 

五、注意事项

1、加法问题

  对于两对象的相加,则相加项的格式必须相同否则报错,相加:数值相加、元素增加……

In [20]: a=[1,2,3]
In [21]: b=["zhang","jia","cai"]
In [22]: a+b  #加法方式的内容追加,前后相加的格式必须相同Out[22]: [1, 2, 3, 'zhang', 'jia', 'cai']

In [23]: c=123In [24]: d="123"In [25]: c+d---------------------------------------------------------------------------TypeError Traceback (most recent call last) in ()----> 1 c+d
TypeError: unsupported operand type(s) for +: 'int' and 'str'

2、乘法问题

  对于乘法中的*,如果数字相乘则为其本意=数与数的乘积运算,如果字符串*一个数字则表示字符串的重复显示,如下:

In [27]: a=123In [28]: a*3Out[28]: 369In [29]: b="123"In [30]: b*3Out[30]: '123123123'