集合操作:
·去重,把一个列表边城集合,就自动去重
·关系测试,测试两组数据之前的交集、差集、并集等关系
list_1 = set(list_1) #列表转化为集合,自动去重
list_1.intersection(list_2) #交集 等效 a = list_1 & list_2
list_1.union(list_2) #并集 等效 a = list_1 | list_2
list_1.difference(list_2) #保留list_1中有的,list_2里没有的 等效 a = list_1 - list_2
list_1.issubset(list_2) #判断子集
list_1.issuperset(list_2) #判断父级集
list_1.symmetric_difference(list_2) #去掉交集的并集集合,对称差集 等效 a = list_1 ^ list_2
增:
·list_1.add(999)
·list_1.update([122,223,445]) #添加多项
删:
·list_1.remove(3) #删除数字3
·lisr_1.pop() #随机删除
改:
查:
·print(len(list_1)) #字典长度
文件操作
流程:
·打开文件,得到文件句柄并赋值给一个变量
·通过句柄对文件进行操作
·关闭文件
f = open("yesterday", 'r', encoding="utf-8") #文件赋值给f变量,再操作------文件句柄
'r'--指定模式,读
·print(f.readline()) #单行读取
·for i in range(3):
print(f.readline()) #多行读取
·for index, line in enumerate(f.readlines()): #循环读取
if index == 9:
print('=======================')
continue
print(line.strip()) #strip 把换行和空格都删除
'w'--写,覆盖之前的
'a'--追加, 不覆盖之前的数据
f.truncate(10) #截断, 不写就是清空,指定就从头截断到指定位置
print(f.read(5)) #读五个
print(f.tell()) #读取文件的位置
f.seek(0) #返回文件起始位置,可选择行数
print(f.encoding) #打印文件编码
print(f.fileno()) #返回文件句柄的编号
"+" 表示可以同时读写某个文件:
·r+,可读写文件。【可读;可写;可追加】,写在最后
·w+,写读 ,先创建
·a+,同a
"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)
·rU
·r+U
"b"表示处理二进制文件,二进制文件用二进制读取,避免损坏
·rb
·wb
·ab
f = open("yesterday2", 'rb')
f.write("hellow binary\n".encode()) #写入转码
练习:修改一个文件,先把“yesterday2”,复制到新的文件“yesterday2.bp”中,再分别赋值给"f","f_new"。再找到需要修改的位置,进行替换。最后关闭文件
字符编码与转码
不同编码的转化先转化成 Unicode
例:
s = "你好" #unicode 字符串编码
print(s.encode("gbk")) #转化为gbk编码
print(s.encode("utf-8")) #转化为utf-8编码
#先用编码成utf-8,再用utf-8解码为u字符串,再用gb2312编码
print(s.encode("utf-8").decode("utf-8").encode("gb2312"))
#先用编码成utf-8,再用utf-8解码为u字符串,再用gb2312编码,再用gb2312解码为字符串
print(s.encode("utf-8").decode("utf-8").encode("gb2312").decode("gb2312"))
编程方法:
·面向对象: -----类 class
·面向过程: -----过程 def
·函数式编程:-----函数 def
函数是裸机结构化和过程化的一种编程方法
优点:
·代码重用,减少重复
·保持一致性
·可扩展性
返回值:
·返回值数 = 0;返回none
·返回值数 = 1;返回object--对象
·返回值数 > 1;返回tuple--元组
参数:
·形参和实参
形参:不是实际存在的,是虚拟变量。在定义函数和函数体的时候使用形参,目的是在函数调用时
接受实参。(一一对应)
实参:实际参数,调用函数式传给函数的参数,可以是常量,变量,表达式,函数,传给形参
区别:形参是虚拟的,不占用内存空间,形参变量只有在被调用的时候才会分配内存单元;实参是
一个变量,占用内存空间,数据传送单向——实参传给形参,不能形参传给实参
·位置参数和关键字(关键字在位置参数后边;实参与形参一一对应;关键字调用)
*args-- 接收N个位置参数,转化为元组的形式
**kwargs--接收N个关键字参数,转化成字典的方式
·默认参数
·参数组 --(*—)
局部变量:局部变量只在函数里生效,函数为这个变量的作用域
global school 在函数中声明修改全局变量------(千万别使用,会导致逻辑混乱)
全局与局部变量:
·在子程序中定义的变量成为局部变量,在程序的一开始定义的变量称为全局变量。
·全局变量作用域为整个程序,局部变量是作用域是定义该变量的子程序
·当全局变量和局部变量同名时:
在定义局部变量的子程序中,局部变量起作用,在其他地方,全局变量起作用
递归:函数内部可以调用其他函数,如果一个函数在内部调用自己本身,就为递归函数。
特性:
·必须有一个明确的结束条件
·每次进入深一层递归是,问题规模相比上次递归应有减少
·递归效率不高,递归层次过多会导致栈溢出