Python标识符
在 Python 里,标识符有字母、数字、下划线组成。
在 Python 中,所有标识符可以包括英文、数字以及下划线(_),但不能以数字开头。
Python 中的标识符是区分大小写的。
以下划线开头的标识符是有特殊意义的。以单下划线开头 _foo 的代表不能直接访问的类属性,需通过类提供的接口进行访问,不能用 from xxx import * 而导入;
以双下划线开头的 foo 代表类的私有成员;以双下划线开头和结尾的 foo 代表 Python 里特殊方法专用的标识,如 init__() 代表类的构造函数。
Python有五个标准的数据类型
Numbers(数字)
String(字符串)
List(列表)
Tuple(元组)
Dictionary(字典)
Python支持四种不同的数字类型
int(有符号整型)
long(长整型[也可以代表八进制和十六进制])
float(浮点型)
complex(复数)
python的字串列表有2种取值顺序
从左到右索引默认0开始的,最大范围是字符串长度少1
从右到左索引默认-1开始的,最大范围是字符串开头
List(列表) 是 Python 中使用最频繁的数据类型
列表可以完成大多数集合类的数据结构实现。它支持字符,数字,字符串甚至可以包含列表(即嵌套)。
列表用 [ ] 标识,是 python 最通用的复合数据类型。
列表中值的切割也可以用到变量 [头下标:尾下标] ,就可以截取相应的列表,从左到右索引默认 0 开始,从右到左索引默认 -1 开始,下标可以为空表示取到头或尾。
加号 + 是列表连接运算符,星号 * 是重复操作。
元组是另一个数据类型,类似于List(列表)
元组用”()”标识。内部元素用逗号隔开。但是元组不能二次赋值,相当于只读列表。
字典(dictionary)是除列表以外python之中最灵活的内置数据结构类型
列表是有序的对象结合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。
字典用”{ }”标识。字典由索引(key)和它对应的值value组成。
Python数据类型转换
有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。
以下几个内置的函数可以执行数据类型之间的转换。这些函数返回一个新的对象,表示转换的值。
函数
|
描述
|
int(x [,base])
|
将x转换为一个整数
|
long(x [,base] )
|
将x转换为一个长整数
|
float(x)
|
将x转换到一个浮点数
|
complex(real [,imag])
|
创建一个复数
|
str(x)
|
将对象 x 转换为字符串
|
repr(x)
|
将对象 x 转换为表达式字符串
|
eval(str)
|
用来计算在字符串中的有效Python表达式,并返回一个对象
|
tuple(s)
|
将序列 s 转换为一个元组
|
list(s)
|
将序列 s 转换为一个列表
|
set(s)
|
转换为可变集合
|
dict(d)
|
创建一个字典。d 必须是一个序列 (key,value)元组。
|
frozenset(s)
|
转换为不可变集合
|
chr(x)
|
将一个整数转换为一个字符
|
unichr(x)
|
将一个整数转换为Unicode字符
|
ord(x)
|
将一个字符转换为它的整数值
|
hex(x)
|
将一个整数转换为一个十六进制字符串
|
oct(x)
|
将一个整数转换为一个八进制字符串
|
Python 运算符
算术运算符
比较(关系)运算符
赋值运算符
逻辑运算符
位运算符
成员运算符
身份运算符
运算符优先级
python算术运算符
运算符
|
描述
|
实例
|
加+
|
两个对象相加
|
a + b 输出结果 30
|
减-
|
得到负数或是一个数减去另一个数
|
a - b 输出结果 -10
|
乘*
|
两个数相乘或是返回一个被重复若干次的字符串
|
a * b 输出结果 200
|
除/
|
x除以y
|
b / a 输出结果 2
|
取模%
|
返回除法的余数
|
b % a 输出结果 0
|
幂^
|
返回x的y次幂
|
ab 为10的20次方, 输出结果 100000000000000000000
|
取整除//
|
返回商的整数部分
|
9//2 输出结果 4 , 9.0//2.0 输出结果 4.0
|
以上假设变量a为10,变量b为20
python比较运算符
运算符
|
描述
|
实例
|
== 等于
|
比较对象是否相等
|
(a == b) 返回 False
|
!= 不等于
|
比较两个对象是否不相等
|
(a != b) 返回 true
|
<> 不等于
|
比较两个对象是否不相等
|
(a <> b) 返回 true这个运算符类似 !=
|
>大于
|
返回x是否大于y
|
(a > b) 返回 False
|
< 小于
|
返回x是否小于y
|
|
以上假设变量a为10,变量b为20
所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。注意,这些变量名的大写。(a < b) 返回 true。= 大于等于 - 返回x是否大于等于y。(a >= b) 返回 False。<= 小于等于 - 返回x是否小于等于y。(a <= b) 返回 true。
Python赋值运算符
以下假设变量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
|
Python位运算符
Python位运算符是指:位与&、位或|、位异或^、位取反~、左移位<<、右移位>>等运算符。
Python位运算符主要针对整数类型的数据来操作的,首先把要运算的整数类型的数据转换为二进制形式后再按位进行相关计算。
按位运算符是把数字看作二进制来进行计算的。
下表中变量 a 为 60,b 为 13,二进制格式如下:
a = 0011 1100 b = 0000 1101 a&b = 0000 1100 a|b = 0011 1101 a^b = 0011 0001 ~a = 1100 0011 运算符
运算符
|
描述
|
实例
|
&
|
按位与运算符:参与运算的两个值,如果两个相应位都为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 。~x 类似于 -x-1
|
(~a ) 输出结果 -61 ,二进制解释: 1100 0011,在一个有符号二进制数的补码形式
|
<<
|
左移动运算符:运算数的各二进位全部左移若干位,由 << 右边的数字指定了移动的位数,高位丢弃,低位补0
|
a << 2 输出结果 240 ,二进制解释: 1111 0000
|
>>
|
右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,>> 右边的数字指定了移动的位数
|
a >> 2 输出结果 15 ,二进制解释: 0000 1111
|
& 按位与运算符:参与运算的两个值,如果两个相应位都为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
Python逻辑运算符
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 是非 0,它返回 x 的值,否则它返回 y 的计算值。(a or b) 返回 10
|
not
|
not x
|
布尔”非”
|
如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。not(a and b) 返回 False
|
Python成员运算符
除了以上的一些运算符之外,Python还支持成员运算符,测试实例中包含了一系列的成员,包括字符串,列表或元组。
运算符
|
描述
|
实例
|
in
|
如果在指定的序列中找到值返回 True,否则返回 False
|
x 在 y 序列中 , 如果 x 在 y 序列中返回 True
|
not in
|
如果在指定的序列中没有找到值返回 True,否则返回 False
|
x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True
|
Python身份运算符
身份运算符用于比较两个对象的存储单元
运算符
|
描述
|
实例
|
is
|
is 是判断两个标识符是不是引用自一个对象
|
x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False
|
is not
|
is not 是判断两个标识符是不是引用自不同对象
|
x is not y , 类似 id(a) != id(b)。如果引用的不是同一个对象则返回结果 True,否则返回 False
|
注:is 与 == 区别:
is 用于判断两个变量引用对象是否为同一个, == 用于判断引用变量的值是否相等。