Python基本语法_运算符详解

目录

  • 目录
  • 前言
  • 软件环境
  • 身份运算符
  • 算术运算符
  • 比较运算符
  • 位移运算符
  • 自变运算符
  • 位运算符
  • 逻辑运算符
  • 成员关系运算符
  • Python真值表
  • 最后

前言

在前面的博文介绍了Python的数据结构之后,接下来结合Python操作符来对Python程序中的数据进行处理。操作符/运算符的使用,可简洁地表示内建类型的对象处理。主要是对程序中的数据进行逻辑操作、算术操作、比较操作等动作行为,本质是将在程序中会非常常用的程序操作封装成成类或函数后,再以字符的形式调用,使执行程序语言更加简洁和符合国际化。

软件环境

  • 操作系统
    • UbuntuKylin 14.04
  • 软件
    • Python 2.7.6
    • IPython 4.0.0

身份运算符

身份运算符用来判断两个变量的引用对象是否指向同一个内存对象,即id(varibale1) ?= id(variable2)。
is:判断两个标识符是不是引用自一个对象
is not:判断两个标识符是不是引用自不同对象
需要注意的是: is 和 == 的意义并不相同。

In [11]: [] == []
Out[11]: True

In [12]: [] is []
Out[12]: False

概括性而言,is 是判断两个变量是否引用同一个对象,而 == 则是判断两个变量引用的对象的值是否一致。要很好的理解两者间的区别需要从Python对象的三要素说起。
Python对象的三要素:id、type、value
id:是对象的唯一标识,是对象在内存中的存储地址。
type:是对象的数据类型
value:是对象的值,是对象在内存中存放的数据。
其中is的判断依据是对象的id,== 的判断依据是对象value,例如:

In [25]: name1 = {'fan':'jmilk'}

In [26]: name2 = name1.copy()

In [27]: name1 == name2
Out[27]: True

In [28]: name1 is name2
Out[28]: False

In [29]: id(name1),id(name2)
Out[29]: (140197805793640, 140197805796720)

上述例子,name2是name1调用copy( )函数后返回的一个新的对象,所以两者的id( )不相等,而两个变量在内存和中的vale却是相等的。

算术运算符

Operator Description
+\- 加\减,其中’+’可以重载为连接符,连接两个字符或字符串
*\** 乘\求平,其中*可以重载为重复
/\%\// 除\求余\取整除,其中%可以重载为格式化,取整除返回商的整数部分

**注:**Python除法需要注意的方面(Python 2.x版本,3.x版本不存在此问题)
1.Python中int型的数值相除,只能得到int型不会返回小数。若返回值需要精确到小数时,有两种方法。
方法一:除数或被除数需要有一者为float型数值。

In [75]: float(1)/2
Out[75]: 0.5

方法二:import未来支持的语言特征division(精确除法)
Python的’/’除法默认使用截断除(Truncating Division),导入division模块后,Python才会默认使用精确除法。当导入了精确除后,若想再使用截断除,可以使用取整除’//’,同时也被成为地板除。

In [92]: %%file testFloat.py
from __future__ import division
a = 1
b = 2
print a/b
   ....: print a//b
   ....:
Overwriting testFloat.py

In [93]: run testFloat.py
0.5
0

随便介绍两个内建函数round(number[, ndigits])、divmod(x, y)
round(x[,n]):给定一个浮点数x,并按照指定精度返回一个浮点数对象,官方文档如下:

In [109]: round.__doc__
Out[109]: 'round(number[, ndigits]) -> floating point number\n\nRound a number to a given precision in decimal digits (default 0 digits).\nThis always returns a floating point number.  Precision may be negative.'

例子:

In [124]: round(1.11111111111,5)
Out[124]: 1.11111

除了使用这种方法获取指定精度的浮点数外,还可以使用%格式化来输出指定精度的浮雕数。

In [125]: a = 1.1111111111

In [126]: print '%.5f' %a
1.11111

%格式化可以非常灵活的得到满足需求的输出数据的格式,以后我们会继续了解。
divmod(x, y):计算x,y的取整除和余数,并以元组类型返回。官方文档:

In [131]: divmod.__doc__
Out[131]: 'divmod(x, y) -> (quotient, remainder)\n\nReturn the tuple ((x-x%y)/y, x%y).  Invariant: div*y + mod == x.'

例子:

In [133]: divmod(7,5)
Out[133]: (1, 2)

比较运算符

Operator Description
> 大于
< 小于
>= 大于等于
<= 小于等于
== 等于,比较两个对象的value是否相等,相等为True
!= 不等于,比较两个对象的value是否不相等,不相等为True
<> 不等于,同!= 运算符

位移运算符

位移运算符是非常有效率的计算方法之一,在对数学运算和对程序执行效率要求高的程序中推荐使用。除了位移运算符之外,Python的按位运算符也是非常有效率的一种数据处理方法,之后会详细的介绍。

Operator Description
<< a << n ⇒ a*(2**n)
>> a >> n ⇒ a/(2**n)

自变运算符

自变运算符可以减少一定的代码量,更重要的是,使用自变运算符可以加快Python程序在内存中的执行效率。
值得注意的是:Python出于避免语法歧义的初衷,在Python语法中并没有自增 i++ 或者 ++i的语法, ++i 只作用于数学运算操作符,如:

In [18]: i = 1

In [19]: ++i
Out[19]: 1

In [20]: +-i
Out[20]: -1

In [21]: --i
Out[21]: 1
Operator Description
+= a+=b ⇒ a=a+b
-= a-=b ⇒ a=a-b
*= a*=b ⇒ a=a*b
/= a/=b ⇒ a=a/b
%= a%=b ⇒ a=a%b
**= a**=b ⇒ a=a**b
//= a//=b ⇒ a=a//b

顺便来比较一下 i = i+1 、i += 1 、i++ 三者间执行效率的高低(对一般编程语言而言)。
最低 i = i + 1
(1). 读取右i的地址
(2). i+1
(3). 读取左i的地址
(4). 将右i+1传递给左i,编译器认为左右两个i是不一致的。
其次 i += 1
(1). 读取左i的地址
(2). i+1
(3). 将i+1传递给i自身,编译器会认为只有同一个i
最高 i++
(1). 读取i的地址
(2). 自增1
注意:在考虑到提升程序运行效率的同时,也要注意在使用i += 1的时候可以会莫名其妙的出现语法错误,这种时候可以考虑是否为数据类型的类型隐式转换错误。
以上的比较只是针对一般的编程语言而言,在Python中因为存在可变对象和非可变对象,而且不存在i++自增语言。但是使用自变运算符,的确可以有效的减少代码量和使程序更加简洁。

位运算符

Operator Description
x | y 按位或(有1则1)
x & y 按位与(有0 则0)
x ^ y 位异或(不同为1,相同为0)
~x 取反

在Python中 | 、& 等运算符的意义不在于处理逻辑关系,而是二进制数据的位运算,数字以二进制形式的补码存储和计算,以原码结果来显示。若数字为正值,他的补码就是原码本身。若数字为负值,则他的补码为源码减一再按位取反。两个数字的计算本质是两个二进制补码的计算。
数字计算的实现原理
1的原码:0000 0001 , 补码: 0000 0001 (二进制的首个数字代表符号,不可以改变)
-1的原码:1000 0001 , 补码:1111 1111

In [67]: -1 & 1
Out[67]: 1

即:
1111 1111
0000 0001
—————
0000 0001
其结果原码为 0000 0001(正数的补码就是原码本身)

In [68]: -1 | 1
Out[68]: -1

即:
1111 1111
0000 0001
—————
1111 1111
其结果原码为1000 0001(负数的原码为补码减一再按位取反,首个数字代表符号不可以改变)
所以,从数字计算的底层实现可以看出。位移运算符是计算效率非常高的一种计算方法,尤其可以避免类似执行乘法时,所带来的非常繁复的操作和实现过程。

逻辑运算符

Operator Description
and 逻辑与
or 逻辑或
not 逻辑非

在Python只能够将and、or、not三种运算符用作于逻辑运算,而不像C、Java等编程语言中可以使用&、|、!,更加不能使用简单逻辑于&&、简单逻辑或||等逻辑运算符。由此可见,Python始终坚持着“只用一种最好的方法,来解决一个问题”的设计理念

成员关系运算符

成员运算符能够判断一个指定对象是否是作为一个容器中的元素,由此来判断两个对象间的关系。
容器:包含了其他对象的引用的数据类型。

Operator Description
in 当一个对象存在一个容器中时为Ture
not in 当一个对象不在一个容器中时为True
In [72]: 1 in list
Out[72]: True

In [73]: 4 in list
Out[73]: False

In [74]: 4 not in list
Out[74]: True

In [75]: 1 not in list
Out[75]: False

Python真值表

Object Constant Value
“” False
“Str” True
0 False
1 True
()空元组 False
[]空列表 False
{}空字典 False
None False

最后

运算符在程序中一直都充当着非常重要的角色,可能是编程的过程中并不会完全用的上,但是建立一个由自己编写起来的运算符文档,在往后的程序编写中会变得非常的方便。

Jmilk

时间: 2024-11-17 18:13:52

Python基本语法_运算符详解的相关文章

Python基本语法_异常处理详解

目录 目录 异常 异常类型 异常处理 触发异常raise 传递异常 assert语句触发异常 捕获异常tryexceptelse 捕捉多个异常 tryfinally语句 自定义异常 withas触发异常自动关闭资源 as获取异常信息 异常参数 traceback追踪异常 sysexc_info获取异常信息 最后 异常 异常即非正常状态,在Python中使用异常对象来表示异常.若程序在编译或运行过程中发生错误,程序的执行过程就会发生改变,抛出异常对象,程序流进入异常处理.如果异常对象没有被处理或捕

PHP读书笔记_运算符详解

什么是运算符 什么是运算符?运算符是告诉PHP做相关运算的标识符号.例如,你需要计算123乘以456等于多少,这时候就需要一个符号,告诉服务器,你需要做乘法运算. PHP中的运算符有哪些?PHP运算符一般分为算术运算符.赋值运算符.比较运算符.三元运算符.逻辑运算符.字符串连接运算符.错误控制运算符. PHP中的算术运算符 算术运算符主要是用于进行算术运算的,例如:加法运算.减法运算.乘法运算.除法运算.在PHP中的常用的算术运算符对应下表: PHP中的赋值运算符 PHP的赋值运算符有两种,分别

PHP读书笔记_运算符详解_php实例

什么是运算符 什么是运算符?运算符是告诉PHP做相关运算的标识符号.例如,你需要计算123乘以456等于多少,这时候就需要一个符号,告诉服务器,你需要做乘法运算. PHP中的运算符有哪些?PHP运算符一般分为算术运算符.赋值运算符.比较运算符.三元运算符.逻辑运算符.字符串连接运算符.错误控制运算符. PHP中的算术运算符 算术运算符主要是用于进行算术运算的,例如:加法运算.减法运算.乘法运算.除法运算.在PHP中的常用的算术运算符对应下表:   PHP中的赋值运算符 PHP的赋值运算符有两种,

Python基本语法_输入/输出语句详解

目录 目录 前言 输入 raw_input input raw_input 和 input 的区别 输出 print print 基本格式化输出 print复杂格式化输出 flags标志位 width宽度 precision精度 dictionaryName字典 print自动换行底层实现 最后 前言 程序最基本需要的两个要素,一个是数据,另外一个便是逻辑.而控制语句在程序中扮演的角色便是实现程序的逻辑,即数据的导向和对数据的操作.当然,这并不代表,程序中的数据的行为只能通过控制语句来实.但在P

Python基本语法_控制流语句_if/while/for

目录 目录 前言 软件环境 If 语句 While循环 break continue for 循环 遍历String 遍历Tuple 遍历List 遍历Dictionary 最后 前言 控制流语句用于改变程序语句流(默认为自上而下顺序执行)的执行顺序,其中Python的基本控制流语句,主要有以下3种: 1. if 语句:根据条件返回的结果执行相应的代码块 2. for 循环:通过遍历容器对象的索引来实现循环 3. while 循环:根据条件返回是否为True来判断是否执行循环体 在本篇中主要会介

Python中的下划线详解

  这篇文章主要介绍了Python中的下划线详解,本文讲解了单个下划线直接做变量名.单下划线前缀的名称.双下划线前缀的名称等内容,需要的朋友可以参考下 这篇文章讨论Python中下划线_的使用.跟Python中很多用法类似,下划线_的不同用法绝大部分(不全是)都是一种惯例约定. 一. 单个下划线直接做变量名(_) 主要有三种情况: 1. 解释器中 _符号是指交互解释器中最后一次执行语句的返回结果.这种用法最初出现在CPython解释器中,其他解释器后来也都跟进了. 代码如下: >>> _

Python中的默认参数详解

  这篇文章主要介绍了Python中的默认参数详解,本文讲解了默认参数的基本原理.如何正确地使用可变参数等内容,需要的朋友可以参考下 文章的主题 不要使用可变对象作为函数的默认参数例如 list,dict,因为def是一个可执行语句,只有def执行的时候才会计算默认默认参数的值,所以使用默认参数会造成函数执行的时候一直在使用同一个对象,引起bug. 基本原理 在 Python 源码中,我们使用def来定义函数或者方法.在其他语言中,类似的东西往往只是一一个语法声明关键字,但def却是一个可执行的

关于正则表达式基本语法的应用详解(必看篇)

1.正则表达式基本语法 两个特殊的符号'^'和'$'.他们的作用是分别指出一个字符串的开始和结束.例子如下: "^The":表示所有以"The"开始的字符串("There","The cat"等): "of despair$":表示所以以"of despair"结尾的字符串: "^abc$":表示开始和结尾都是"abc"的字符串--呵呵,只有&qu

php中的三元运算符详解

php教程中的三元运算符详解 三元运算符的功能与"if....else"流程语句一致,它在一行中书写,代码精练.执行效率高.在PHP程序中恰当地使用三元运算符能够让脚本更为简洁.高效.代码的语法如下: (expr1)?(expr2):(expr3);   解释:如果条件"expr1"成立,则执行语句"expr2",否则执行"expr3". 实现同样的功能,若使用条件流程语句,就需要书写多行代码:  if(expr1){ exp