当前位置: 移动技术网 > IT编程>脚本编程>Python > Python基础---变量

Python基础---变量

2019年09月19日  | 移动技术网IT编程  | 我要评论

汽车货运运费查询,刘积斌,泡泡战士烂苹果

什么是变量:

用来绑定数据对象的标识符

一.变量的命名规则:

  • 变量名必须为字母或下划线开头,后跟字母或下划线或数字
  • 不能使用python的关键字命名
  • 命名规则可以被视为一种 惯例,并无绝对与强制
  • 目的是为了 增加代码的识别和可读性
  • 在定义变量时,为了保证代码格式,= 的左右应该各保留一个空格
  • 在python中,如果变量名需要由 二个 或 多个单词 组成时,可以按照以下方式命名
  1. 每个单词都使用小写字母
  2. 单词与单词之间使用 _下划线 连接
  3. 例如:first_name、ast_name、qq_number、qq_password
  • 当 变量名是由二个或多个单词组成时,还可以利用驼峰命名法来命名
  1. 小驼峰式命名法:第一个单词以小写字母开始,后续单词的首字母大写。例如:firstname、lastname
  2. 大驼峰式命名法:每一个单词的首字母都采用大写字母。例如:firstname、lastname、camelcase
#合法的变量命名示例:

a   a1  b  bbb  _aaa_ _abcdvara1b2c2

#不合法的变量命名示例:

1a  123  $abc +a -b  #ab @ab

关键字:

  • 关键字就是在python内部已经使用的标识符
  • 关键字具有特殊的功能和含义
  • 开发者不允许定义和关键字相同的名字的标示符

查看关键字:

import keyword
print(keyword.kwlist)
#['false', 'none', 'true', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']

二.变量的赋值:

赋值语法:

变量名=表达式

变量名1=变量名2=表达式

变量名1,变量名2,...=序列

变量名1,变量名2,...=对象1,对象2...

变量名1,变量名2,...=[对象1,对象2...]

变量名1,变量名2,...=(对象1,对象2...)

作用:用于创建变量并将变量绑定(或关联)在一个对象上

说明:

  • 当变量不存在时,创建该变量同时绑定在这个对象上
  • 当变量存在时,改变此变量的绑定的对象
  • 一个变量只能绑定一个对象
  • 两个变量可以同时绑定一个对象

示例:

a=10      #创建a变量,和整型对象10绑定在一起

b=20

c=a+b   #创建变量c,和10+20的计算结果绑定在一起

名词解释:

关联/绑定/引用在python中的含义,变量是没有类型的,关联/绑定/引用都是指变量和一个对象的关联关系

可以通过help('__main__')来查看当前模块下的数据关联关系

三.python的自动化内存管理:

python 的内存管理和引用计数

每个对象都会记录有几个变量引用自身,当引用的数量为0时,则对象被销毁,此种自动化内存管理的方式叫引用计数。

a = 10000
b = 20000

a = a + b # 发生了什么?
c = a # 发生了什么?

#a = 10000 内存中创建一个10000对象,用变量a和10000绑定绑定
#b = 20000 内存中创建一个 20000对象,用变量b和20000对象绑
#a = a + b 计算对象a 和 b 的和,创建一个30000的对象,a 解除与10000对象的绑定,重新绑定30000这个对象

#c = a 变量c和变量a绑定同一个对象

变量的交换绑定

#练习:已知有两个变量:a 绑定 10000 b 绑定 20000
#问:在不创建任何新的对象的情况下,如何让a和b 交换绑定的对象?
#方法1:
a = 10000
b = 20000
temp = a #借助第三个变量,经典交换算法
a = b
b = temp

#方法2:序列赋值 
a, b = b , a

四.变量的is与==

  • is 比较的是两个实例对象是不是完全相同,它们是不是同一个对象,占用的内存地址是否相同。莱布尼茨说过:“世界上没有两片完全相同的叶子”,这个is正是这样的比较,比较是不是同一片叶子(即比较的id是否相同,这id类似于人的身份证标识)。
  • == 比较的是两个对象的内容是否相等,即内存地址可以不一样,内容一样就可以了。这里比较的并非是同一片叶子,可能叶子的种类或者脉络相同就可以了。默认会调用对象的 __eq__()方法。

获取对象的内存地址:id 函数
格式:id(对象)
作用:返回一个对象在内存中的地址

可以通过如下例子来区分比较下:

>>> a = ["i", "love", "python"]
>>> b = a
# a的引用复制给b,在内存中其实是指向了用一个对象
>>> b is a
true
>>> id(a)
46381384
>>> id(b)
46381384
# 当然,内容也肯定是相等的
>>> b == a
true

可以发现b和a的内存地址是相同的,它们指向同一块内存,因而 is 和 == 的结果都为true。这是因为直接赋值都是赋值的引用,是引用,是引用,重要的事情说三遍。

但如果不是通过引用赋值,而是通过切片赋值呢?

# b通过切片操作重新分配了对象,但是值和a相同
>>> b = a[:]
>>> b is a
false
>>> id(a)
48740680
>>> id(b)
48740680
>>> b == a # 但他们的值还是相等的
true

新建对象之后,b 和 a 指向了不同的内存,所以 b is a 的结果为false,而 b==a的结果为true。

在这里,小编提一个问题,b[0] is a[0] 的结果呢?

答案是true。

因为切片拷贝是浅拷贝,列表中的元素并未重新创建。

通常,我们关注的是值,而不是内存地址,因此 python 代码中 == 出现的频率比 is 高。

但是什么时候用 is 呢?

is 与 == 相比有一个比较大的优势,就是计算速度快,因为它不能重载,不用进行特殊的函数调用,少了函数调用的开销而直接比较两个整数 id。而 a == b 则是等同于a.__eq__(b)。继承自 object 的 __eq__ 方法比较两个对象的id,结果与 is 一样。但是多数python的对象会覆盖object的 __eq__方法,而定义内容的相关比较,所以比较的是对象属性的值。

在变量和单例值之间比较时,应该使用 is。

目前,最常使用 is 的地方是判断对象是不是 none。

下面是推荐的写法:

a is none

判断不是none的推荐写法是:

a is not none

python会对比较小的整数对象进行缓存,下次用的时候直接从缓存中获取,所以is 和 == 的结果可能相同:

>>> a = 1
>>> b = 1
>>> a is b
true
>>> a == b
true

而看一下另外一段代码:

>>> a = 257
>>> b = 257
>>> a is b
false

原因:

python仅仅对比较小的整数对象进行缓存(范围为范围[-5, 256])缓存起来,而并非是所有整数对象。需要注意的是,这仅仅是在命令行中执行,而在pycharm或者保存为文件执行,结果是不一样的,这是因为解释器做了一部分优化。

总结

  • is 比较两个对象的 id 值是否相等,是否指向同一个内存地址;
  • == 比较的是两个对象的内容是否相等,值是否相等;
  • 小整数对象[-5,256]在全局解释器范围内被放入缓存供重复使用;
  • is 运算符比 == 效率高,在变量和none进行比较时,应该使用 is。

五.变量的删除

del 语句(del 是 delete 的简写)
作用:用于删除变量,同时删除与对象的绑定关系。如果可能则释放对象
语法:del 变量名

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网