1、Python的两种编程方式:交互式(随输随运行)和文件式(主要方式;批量运行出结果)
2、一切皆对象,每个对象由标识(id())、类型(type())和值(print())标识。
3、Python采用基于值的内存管理
,不同变量赋值为同一个值,ID一样,但是只适用范围在-5至256的整数和短字符串。
4、内置函数(BIF),68个,查看方式:dir(builtins)
分类:
数值
数据类型:int,float,complex,bool,decimal,fractions
序列
数据类型:字符串(string)、列表(list)、元祖(tuple)、bytes、bytearray
集合
数据类型:set、frozenset
字典
数据类型:dict
不可变的数据类型:数值Number、字符串String、元祖Tuple
可变的数据类型:列表List、字典Dict、集合Set
5、
二进制:0b/0B开头
八进制:0o/0O开头
十六进制;0x/0X开头
6、
数值运算函数:
abs(x):绝对值 ;divmod(x,y):商余 ;pow(x,y,z):幂余((x**y)%z) ;round(x,d):四舍五入d位 ;max/min ; int(x) /float(x) /complex(x)
7、
math库:
常数:math.pi ;math.fabs(x):绝对值 ;math.fmod(x,y):x%y ;math.ceil(x):向上取整,返回不小于x的最小整数 ;math.floor(x):向下取整,返回不大于x的最大整数 ;math.modf(x):返回x的小数和整数部分 ;math.trunc(x):返回x的整数部分
8、
浮点数类型:0.1 + 0.2不等于 0.3 ,浮点数有小尾数。看是否等于可以用round()函数帮助去小尾数。
9、类型间混合运算:
整数 -> 浮点数 -> 复数
10、布尔数据类型(bool)包含两个值->True(真–1)或假(False–0)。
如果表达式的结果为数值类型的0、空字符串(“”)、空元祖()、空列表[]、空字典{},则其布尔值为false(假),否则为true(真)。
11、逻辑运算符:and、or、not
a and b等于a if not a else b ; a or b 等于a if a else b。
not一定会返回true或false;and和or不一定。
12、运算优先级(由高到低)
**
(指数)> +x.-x(正负号)> *./.%(乘。除。取余)> +. -(加。减)> &(与)> ^(或)> \(非)>比较大小> not(非)> and(与)>or(或)> lambda表达式
13、序列型数据
(1)序列的索引s[i]:如果索引下标越界,导致IndexError;如果索引下标不是整数,导致TypeError。
(2)序列的切片(截取序列s的一部分):顾头不顾尾。
(3)序列的加:x + y:连接两个序列; 序列的乘(复制):x * n:复制n次序列x ;
(4)判断子串:x in s :返回True/False ; s.count(x):返回x在s中出现的次数 ; s.index(x,i,j):返回x在s(范围[i,j])中第一次出现的索引位置。
(5)序列的排序:sorted(s, key=None,reverse=False)。reverse为false是为升序,为true时为倒序。返回结果为一个列表。
(6)序列的拆封赋值:当变量个数和序列长度相等时,一一对应赋值。如a,b = (1,2)即a = 1,b = 2。不等则导致ValueError。或使用变量(将多个值作为整体赋给变量)或使用临时变量‘_’
14、字符串类型
15、列表类型
[index]
):删除并返回指定位置的元素(可以理解为挖取出),list为空就抛IndexError异常;b = a[:]
,两个变量相互独立的。但如果拷贝对象只有一层,就会有影响,会跟着改变。(详见例题)[新元素表达式 for 临时变量 in 可迭代对象 if 条件表达式]
16、集合类型
集合中的元素没有顺序,且不重复。集合set是可变的,用大括号表示。
但是{}表示空字典;set()表示空集合,用set()创建集合时,会将元素一个一个拆开,如’hello’变成’h’,‘e’,‘l’,‘l’,‘o’。
集合中元素要是固定数据类型:整数、浮点数、字符串、元组等。不可为可变的列表、字典、集合。
利用集合过滤掉重复的元素。
4种基本操作:交(&)、并(|)、差(-)、补(^)
S.add() ;S.clear() ;S.copy() ; S.remove() ;len(S) ;x (not)in S ;
**S.pop():随机返回S中的一个元素,如果S为空,产生KeyError.(区分list.pop([index]))
特有的:S.discard(X);如果x在S中,移除x,不在,不报错。
主要三大用途:成员关系测试、元素去重、删除数据项。
17、字典类型(映射)
{建(key):值(value)}。键不能重复,且是不可变对象。值可变。元素没有顺序。
创建一个空字典:dict() ;创建字典:dict(‘a’=1,‘b’=2)/dict(‘a’:1,‘b’:2)/dict((‘a’,1),(‘b’,2))
查找值:Dict[key] ;修改键值:dict[key] = new_value ;增添新键值:dict[new_key] = new_value .
D.keys():返回所有键的列表,如dict_keys([‘a’, ‘b’, ‘c’]);
D.values():返回所有值的列表,如dict_values([1, 2, 3]);
D.items():返回所有的键值对的列表,如dict_items([(‘a’, 1), (‘b’, 2), (‘c’, 3)]);
D.get(key,v):键存在则返回相应值,否则返回None(自定义了v时,返回v的内容);
D.pop(key.value):键存在则返回相应值,同时删除键值对,否则返回None;
D.popitem():随机取出一个键值对,以元组(key,value)形式返回;
D.setdefault(k,v):如果键k存在,返回对应值,否则添加项目k = v,v默认为None;
D.update(dict):更新或添加键值对;
D.clear():删除所有的键值对;
del.D[key]:删除key对应的键值对。如果key不存在,则抛出KeyError。 遍历:
for 变量名 in 字典名:
18、可变与不可变(关于值)
可变:列表(有序)、集合(无序)、字典(无序)
不可变:字符串(有序)、元组(有序)
Python是基于值的内存管理方式,举例:a=[1,2,3],b=[1,2,3],a==b成立。 但是id(a)与id(b)不相等,id(a[0])==id(b[0])成立。总结就是关乎值的就相等
什么叫可变?即值是可变的,但id是固定不变的。例如可变的列表,修改列表L中的一个元素的值,列表L的id是不变的。
不管是可变还是不可变的序列类型:
(1)分片必定产生新的序列;
(2)“+”号在等号右边(L=L+[i]),必定产生新的序列。然后将新的序列地址赋予给等号左边的变量。(每一次执行时都会将原列表复制一次,L指向新列表,并在新列表中加入新元素)
对三种列表添加方法进行总结:
(1)L=L+[i]在每一次执行时都会将原列表复制一次,L指向新列表,并在新列表中加入新元素。
(2)L.append(i)只是将新元素直接添加到原列表中,不会产生新列表。
(3)L+=[i]的执行效果和L.append(i)类似,也是在原列表中直接添加元素,不会复制原列表。
b = a VS b = a[:]
b = a时,b就是跟着a变化,并且a与b的id一样。b = a[:]时,b与a是独立的整体,id就不同,只不过指向了同一个值。对a做修改(增删改查),对b没有影响。
19、程序的三种基本结构:
顺序结构、·分支结构(if-else、elif)、·循环结构(遍历:for…in、条件:while。循环控制:break/continue)。
异常值处理:try-except。
二分支结构简单语法:表达式1 if 条件 else 表达式2
循环结构分遍历循环(for)和无限循环(while):
遍历循环:for 循环变量 in 遍历结构:语句块(从遍历结构逐一提取元素,放在循环变量中,对每一个提取出的元素执行一次语句块。)
无限循环:while 条件:语句块。判断条件为True就一直循环,为false时魂环结束,执行与while同级别缩进的后续语句。
break用于结束当前循环,如果有两层循环,break用于跳出最内层for或while循环,脱离该循环后程序从循环后代码继续执行;
continue用来结束当前循环的当次循环过程,即跳出循环体中下面尚未执行的语句,但不跳出当前循环。
当有输入要求时,可运用异常值处理try:except:
20、函数
(1)形参与实参:定义函数时的参数是形参,调用函数时的参数是实参。
(2)参数传递的方法:位置参数、默认值参数、关键字参数、命名关键字参数。。。
位置参数:按位置顺序传递参数值,位置参数要在所有参数之前,是第一个参数;
关键字参数:关键字参数就是在调用函数,传入实参时指定形参的变量名。关键字不用遵守位置的对应关系。参数之间的顺序可以任意调整。关键字传递可以和位置传递混用。但位置参数要在关键字参数之前。举例:def hello(name,age = 11,gender = ‘F’):(age = 11,gender = 'F’就是关键字参数)
。举例:def hello(name,age = 11,gender = ‘F’):(age = 11,gender = 'F’就是关键字参数)
默认值参数:定义参数时已经给定值,一般参数为不可变对象,(如果为可变的空列表,可用于装位置参数);
可变数量参数:*args、**kw
带有星号*
的可变参数只能出现在参数列表的后面。调用时,*参数
被当作元组类型传递到函数中。(如: def func(*args): -> func(10,20)
)
带双星号(**
)的参数,在使用时必须指定参数值,使用key=value这种形式,只能出现在参数列表的最后。调用时,**kw
后的那些参数被当作字典类型传递到函数中。(如:def func(**kw): -> func(a=10,b=20)
)
强制命名参数:参数带星号或者就是一个星号(def f(*c或*,a,b,c)
),强制命令参数*c
的含义是它后面的参数必须用实名调用,即必须用 a = … , b = … 来调用,不能只写值。
Python中只有函数,函数是有返回值的,**如果没有return,默认返回None。**return返回多个值时,多个值以元组形式保存。
21、比较
(1)list.sort()与全局sorted()
list.sort(key = None,reverse = False)是列表内置排序方法。但其返回值为None(x.sort()的结果、print(x.sort())、x = x.sort()后x的结果都是None),只有当文字说“执行语句x.sort(),x的值为”,x.sort()作用的结果,需要通过打印被作用的列表才可以查看结果。true是倒序,false是正序。
sorted():Python内置方法。返回新的列表。
(2)list.reverse()和reversed()
list.reverse()返回的是None,其作用的结果,需要通过打印被作用的列表才可以查看结果。
reversed():内置方法。经过reversed()作用之后,返回的是一个吧序列值经过倒序的迭代器,所以,需要通过遍历或list、tuple或next()方法,才能获得作用后的值。
(3)字符串的查找:find和index
str.find(s):从左至右查找str中是否含s,有则返回第一次出现s的索引位置,否则返回-1
str.index(x):从左至右查找是否含有x,有则返回第一次出现的索引位置,没有则抛出ValueError
str.rfind()和str.rindex()就是从右至左查找。
22、函数变量的作用域
(1)局部变量、全局变量、global
global:用于在函数中直接修改全局变量的值。
(2)内嵌函数
内嵌函数的作用域仅限其所在的函数体内。如果要在内部函数中修改外部函数中的局部变量的值,使用nonlocal关键字。