分享

UC头条:清华毕业大佬整理的Python基础22大知识点, 自备热水, 这货有点干

 bdpqlxz 2020-04-28

最近整理了一些Python基础教程,像数据分析、数据类型、字符串、正则表达式以及最新版Python3.8安装程序,很多小伙伴都反映不错,也都领取了相应学习资料。今天咱们就来整理一些干货,带大家由浅及深的剖析一下最近的学习教程。

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、字符串类型

比较字符ASCII码值的大小:空格<数字<大写字母<小写字母

Unicode变字符:chr(u) ;字符变Unicode:ord(x)

format方法的格式控制:

(1)槽{序号}的使用

(2){参数序号:格式控制标记},格式控制标记包括:填充、对齐(分别用<、>、^表示左、 右和居中对齐)、宽度、精度、类型(b=二进制,c=Unicode,d=十进制,o=八进制,xX=十六 进制)。

字符串的类型判断:

str.isdigit是否全为数字(0-9);str.isalpha是否全为字母;str.isal num是否全为数字或字母;str.isspace是否是空白(空格、制表符、换行符等);str.isprintable是否可打印(空格和没有东西是可以被打印的);str.isidentifier是否满足标识符定义规则(字母或下划线开头,只含数字、字母和下划线)

大小写转换:str.capitaiize:转换为首字母大写,其余小写;str.title各单词首字母大写。

对齐:居中str.center(长度,填充物) ;左对齐:ljust ;右对齐:rjust。

填充:str.zfill(长度)相当于右对齐,前方补0。如果str前有正负号,则正负号也算长度,在正负号之后填充。

移除:左右两边:str.strip(字符chars) ; 左边:str.lstrip ;右边;rstrip

字符串的查找:find和index

str.find(s):从左至右查找str中是否含s,有则返回第一次出现s的索引位置,否则返回-1

str.index(x):从左至右查找是否含有x,有则返回第一次出现的索引位置,没有则抛出ValueError

str.rfind和str.rindex就是从右至左查找。

字符串的替换:S.replace(old,new,count)。将S中的old替换为new,如果给定count,则只替换前count个old子串。

拆分/分割:

S.split(分隔符sep,分割次数maxsplit), maxsplit = -1或不指定时,会从左向右搜索完整个字符串。S.rsplit是从右往左。生成列表。

S.partition(sep),S.rpartition(sep)(从右往左搜索)。搜索S中的子串sep,并从第一个sep处分割,返回一个包含三个元素的元组 -->(sep左边的部分,sep,sep右边的部分)。如果搜索不到sep,则返回中有两个元素为空,partition是后两个元素为空,rpartition是前两个为空。

连接组合:S.join(字符串对象)。 当对象为字符串字典时,结果是键的连接。

15、列表类型

列表list是可变对象,则对其增删改查不会改变其的id。除了list.copy.

方法:

(1)添加:

list.appand(x):将元素x添加到列表的尾部;

list.extend(L):将列表L中所有元素添加到列表的尾部;

list.insert(index,x):在列表指定位置index处添加元素x;

(2)删除:

list.remove(x):删除列表中首次出现的元素x;

list.pop(kediedai[index]):删除并返回指定位置的元素(可以理解为挖取出),list为空就抛IndexError异常;

list.clear:删除列表中所有元素,但保留列表对象。

(3)排序:

list.reverse:倒序;

list.sort:排序(正或倒);

(4)其他:

list.index(x):返回值为x首次出现的下标;

list.count(x):返回x的出现总次数;

list.copy :返回列表对象的浅拷贝。很厉害!!它可以改变列表的ID!

**浅拷贝——只拷贝一层。**如果拷贝对象只有一层,那么同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时,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关键字。

这些常见知识点,你都掌握了吗?

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多