///////////////////////////////////////////////////
//
// Python 语法
//
////////////////////////////////////////////////////
一、Python 基本知识
【特点】
1. 跨平台
2. 面向对象
3. 像胶水,可以连接两个语言编程
4. 编程简单
【基本】
1. 脚本解释说明
#!/usr/bin/python //在 unix/linux 下 才会有这句,windows下没有
2. 编码方式说明
# -*- coding: UTF-8 -*- // 设置编码方式,否则会影响代码解释,输出
3. 严格行和缩进
1)不是用{} 等来控制,就意味着要严格控制行和缩进
2)可用;显示多条语句(一般不这么做)
4. 多行语句
当一行语句写不完 可用 "" 进行折行
【注释】
1. 单行注释
在单行代码行首 加 "#"
2. 多行注释
用一对三引号''' 或 """ 来包裹多行要注释的代码
二、Python 基本语法
【输入、输出】
键盘输入、屏幕输出.
1. 输入:
a. 数字型等
var = input()
b. 字符串型
var = raw_input() (python3 已舍弃)
返回一个字符串
2. 输出:
a. print
1)利用print + var1,var2,... 输出var (python3中已舍弃)
2)利用print(var) ,输出var
3) end关键字,可以不换行打印
关键字end可以用于将结果输出到同一行,或者在输出的末尾添加不同的字符
a, b = 0, 1
while b < 1000:
print(b, end=',')
a, b = b, a+b
b. write
利用sys模块中stdout对象之write(var) , 输出var
【变量】
1. 创建变量
var1,var2 = 初始值1,初始值2 #分别对var1,var2 进行初始化。
2. 删除变量
del 变量1,变量2
【数据类型】
1. Numbers(数字)
a. int(有符号整型)
b. long(长整型[也可以代表八进制和十六进制])常用大写L表示 [Python3 中舍弃]
c. float(浮点型)
d. complex(复数)
利用a+bj 表示,a 和 b 属于浮点型(数字型),j为复数常量
2. String(字符串)
a. 单引号 成对
表示存粹的字符串,一切皆为字符串。
b. 双引号 成对
可以转义字符等。
c. 三引号 成对
d. Unicode 字符串
在普通字符串前面加上u
3. List(列表)
list = [element1,element2,...]
相当于C语言中数组
特点:
可修改元素的值。
访问:
列表中值的切割也可以用到变量 [头下标:尾下标] ,就可以截取相应的列表,
从左到右索引默认 0 开始,从右到左索引默认 -1 开始,下标可以为空表示取到头或尾。
list[index]
列表推导式
vec = [2, 4, 6]
>>> [3*x for x in vec]
[6, 12, 18]
4. Tuple(元组)
tuple = (element1,element2,...)
特点:
一旦创建,不能修改 元素的值。
访问:
类似List(列表)
5. Dictionary(字典)
dict = {'key1':value1,'key2':value2,...)
特点:
可修改 键、值
访问:
dict[key]
6. Set(集合) [Python3 数据类型]
集合(set)是一个无序的不重复元素序列。
创建:
parame = {value01,value02,...}
或者
set(value)
注:
isinstance 和 type 的区别在于:
type()不会认为子类是一种父类类型。
isinstance()会认为子类是一种父类类型。
不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。
7. 类型转换
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最强大的功能之一,是访问集合元素的一种方式。
iter(集合变量)
next(集合变量)
###########################
>>> list=[1,2,3,4]
>>> it = iter(list) # 创建迭代器对象
>>> print (next(it)) # 输出迭代器的下一个元素
1
>>> print (next(it))
2
创建一个迭代器:
把一个类作为一个迭代器使用需要在类中实现两个方法 __iter__() 与 __next__() 。
生成器:
在 Python 中,使用了 yield 的函数被称为生成器(generator)。
【运算符】
1. 算术运算符
+
相加
-
相减
*
相乘
/
相除
%
取模
**
取幂值
//
取整除 (返回商的整数部分)
2. 比较运算符
比较返回布尔值 False,True.
==
比较俩对象是否相等
!=
比较俩对象是否不相等
<>
比较俩对象是否不相等
>
大于
<
小于
>=
大于等于
<=
小于等于
3. 赋值运算符
=
赋值
+=
加法赋值
-=
减法赋值
*=
乘法赋值
/=
除法赋值
%=
取模赋值
**=
幂赋值
//=
取整除赋值
4. 位运算符
*
按位与
|
按位或
^
按位异或
~
按位取反 类似于 -(x+1)
<<
左移运算符
>>
右移运算符
5. 逻辑运算符
and
两者都为真,结果才为真
or
一者为真,结果为真
not
一者为假,结果为假
6. 成员运算符
in
1) 如果在指定的序列中找到值返回 True,否则返回 False。
2) x 在 y 序列中 , 如果 x 在 y 序列中返回 True。
not in
1) 如果在指定的序列中没有找到值返回 True,否则返回 False。
2) x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。
7. 身份运算符
a. is
比较两者是否是引用自同一个对象
b. is not
比较两者是否是引用自不同一个对象
【条件】
1. if 判断条件: 执行语句(或者换行)
2. if 判断条件:
执行语句……
else:
执行语句……
3. if 判断条件1:
执行语句1……
elif 判断条件2:
执行语句2……
elif 判断条件3:
执行语句3……
else:
执行语句4……
【循环】
1. while 循环
1) while 判断条件:
执行语句……
2) while 判断条件:
执行语句……
else:
执行语句…… # while循环条件不成立时的执行语句
2. for 循环
1) for 元素 in 集合:
执行语句……
2) for 元素 in 集合:
执行语句……
else:
执行语句…… #条件不成立时,执行语句
3. 循环控制语句
1) break
跳出循环,且只能跳出1层。
2) continue
跳过当前循环,继续循环下去
3) pass
注:
1. while 和 for 循环之间是可以互相嵌套使用的。
2. break 、continue 只用于for、while循环中
3. pass 可以用于任意结构中,意为什么也不做。
【函数】
1. 定义函数
def 函数名(参数表):
执行语句
return 返回值
参数表:
a. 可为数据类型
b. 可用默认值,从右向左(一般)
c. 不定长参数的函数定义
def functionname([formal_args,] *var_args_tuple ):
"函数_文档字符串"
function_suite
return [expression]
注:
加了星号(*)的变量名会存放所有未命名的变量参数。
2. 调用(使用)函数
a = 函数名(参数表)
3. 参数
1) 不可更改
a = 5
a = 10 # 这里不是将a赋值为10,而是指向被new一个int 为10的数。
2) 可更改
而list、tuple、dictionary 是可更改的
4. 匿名函数(lambda 表达式)
lambda [arg1 [,arg2,.....argn]]:expression
【模块 & 包】
搜索路径
当你导入一个模块,Python 解析器对模块位置的搜索顺序是:
1、当前目录
2、如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录。
3、如果都找不到,Python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/。
模块搜索路径存储在 system 模块的 sys.path 变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
1. 模块
描述:
Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句。
导入:
描述:
将该模块引用进来
语法:
a. import module1[, module2[,... moduleN]]
导入以上模块
如果有必要,也可以使用 [模块名.函数名] 来进行调用
比如:
math.sin(30);
b. from moduleName import name1[, name2[, ... nameN]]
从模块中导入一个指定的部分到当前命名空间中
c. from moduleName import *
把一个模块的所有内容全都导入到当前的命名空间
dir(moduleName) 函数:
dir() 函数一个排好序的字符串列表,内容是一个模块里定义过的名字。
返回的列表容纳了在一个模块里定义的所有模块,变量和函数
特殊字符串变量__name__指向模块的名字,__file__指向该模块的导入文件名。
globals() 和 locals() 函数
根据调用地方的不同,globals() 和 locals() 函数可被用来返回全局和局部命名空间里的名字。
如果在函数内部调用 locals(),返回的是所有能在该函数里访问的命名。
如果在函数内部调用 globals(),返回的是所有在该函数里能访问的全局名字。
两个函数的返回类型都是字典。所以名字们能用 keys() 函数摘取。
reload() 函数
当一个模块被导入到一个脚本,模块顶层部分的代码只会被执行一次。
因此,如果你想重新执行模块里顶层部分的代码,可以用 reload() 函数。该函数会重新导入之前导入过的模块。
语法如下:
reload(module_name)
2. 包
包是一个分层次的文件目录结构,它定义了一个由模块及子包,和子包下的子包等组成的 Python 的应用环境。
简单来说,包就是文件夹,但该文件夹下必须存在 __init__.py 文件, 该文件的内容可以为空。__init__.py 用于标识当前文件夹是一个包。
考虑一个在 package_runoob 目录下的 runoob1.py、runoob2.py、__init__.py 文件,test.py 为测试调用包的代码,目录结构如下:
test.py
package_runoob
|-- __init__.py
|-- runoob1.py
|-- runoob2.py
导入包:
from package_runoob.runoob1 import runoob1
from package_runoob.runoob2 import runoob2
runoob1()
runoob2()
3. 内置模块
数学模块
1)math
数学模块(常用)
2)cmath
复数模块
【异常处理】
1. try....except...else
try:
<语句> #运行别的代码
except <名字>:
<语句> #如果在try部份引发了'name'异常
except <名字>,<数据>:
<语句> #如果引发了'name'异常,获得附加的数据
else:
<语句> #如果没有异常发生
2. try-finally
try:
<语句>
finally:
<语句> #退出try时总会执行
raise
【面向对象】
1. 类
创建类:
class ClassName:
'类的帮助信息' #类文档字符串
class_suite #类体
注:
类的帮助信息可以通过ClassName.__doc__查看。
class_suite 由类成员,方法,数据属性组成。
实例:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class Employee:
'所有员工的基类'
empCount = 0
def __init__(self, name, salary):
self.name = name
self.salary = salary
Employee.empCount += 1
def displayCount(self):
print "Total Employee %d" % Employee.empCount
def displayEmployee(self):
print "Name : ", self.name, ", Salary: ", self.salary
特殊方法
1) __init__(self):
__init__ 为构造函数,self 为实力本身
2) __del__(self):
析构函数,
你也可以使用以下函数的方式来访问属性:
getattr(obj, name[, default]) : 访问对象的属性。
hasattr(obj,name) : 检查是否存在一个属性。
setattr(obj,name,value) : 设置一个属性。如果属性不存在,会创建一个新属性。
delattr(obj, name) : 删除属性。
实例:
hasattr(emp1, 'age') # 如果存在 'age' 属性返回 True。
getattr(emp1, 'age') # 返回 'age' 属性的值
setattr(emp1, 'age', 8) # 添加属性 'age' 值为 8
delattr(emp1, 'age') # 删除属性 'age'
2. Python内置类属性
__dict__ : 类的属性(包含一个字典,由类的数据属性组成)
__doc__ :类的文档字符串
__name__: 类名
__module__: 类定义所在的模块(类的全名是'__main__.className',如果类位于一个导入模块mymod中,那么className.__module__ 等于 mymod)
__bases__ : 类的所有父类构成元素(包含了一个由所有父类组成的元组)
3. 类继承
class 派生类名(基类名1,基类名2, ...)
...
你可以使用issubclass()或者isinstance()方法来检测。
issubclass() - 布尔函数判断一个类是另一个类的子类或者子孙类,语法:issubclass(sub,sup)
isinstance(obj, Class) 布尔函数如果obj是Class类的实例对象或者是一个Class子类的实例对象则返回true。
子类构造函数(方法):
子类若需要父类的构造方法需要
1) 显示调用父类方法 (重写,创建时完成多态)
super(子类,self).__init__(参数1,参数2, ...)
或
父类名称.__init__(self,参数1,参数2,...)
2) 或者不写父类的构造方法
4. 运算符重载
__add__
__str__
__repr__
__cmp__
...等 魔法方法
5. 访问性
默认为public型访问权限
单下划线、双下划线、头尾双下划线说明:
__foo__: 定义的是特殊方法,一般是系统定义名字 ,类似 __init__() 之类的。
_foo: 以单下划线开头的表示的是 protected 类型的变量,即保护类型只能允许其本身与子类进行访问,不能用于 from module import *
__foo: 双下划线的表示的是私有类型(private)的变量, 只能是允许这个类本身进行访问了。
函数也是如此。