1、函数一
1)函数:一个模块一个模块的执行
2)函数的格式 :def 函数名(参数): 代码
3)函数的调用:直接在函数外边写:函数名()
4)定义时小括号中的参数,用来接收参数用的,称为 “形参”
调用时小括号中的参数,用来传递给函数用的,称为 “实参”
5)返回值:return
6)函数的类型:
1.有参无返
2.有参有返
3.无参无返
4.无参有返
7)函数的嵌套应用:
如果函数A中,调用了另外一个函数B,那么先把函数B中的任务都执行完毕之后才会回到上次 函数A执行的位置
8)函数名不能重名
2、函数二
1)局部变量:就是在函数内部定义的变量
其作用范围是这个函数内部,即只能在这个函数中使用,在函数的外部是不能使用的
2)全局变量:在函数外边定义的变量
全局变量能够在所有的函数中进行访问
3)当函数内出现局部变量和全局变量相同名字时,函数内部中的 变量名 = 数据 此时理解为定义了一个局部变量,而不是修改全局变量的值
4)全局变量的修改:global
5)一个函数中可以有多个return语句,但是只要有一个return语 句被执行到,那么这个函数就会结束了,因此后面的return没有什么用处
6)return 返回多个值时,保存在(默认)元祖中
return后面可以是(默认)元组,列表、字典等,只要是能够存储 多个数据的类型,就可以一次性返回多个数据
7)缺省参数:在形参中默认有值的参数,称之为缺省参数
带有默认值的参数一定要位于参数列表的最后面
调用函数时,缺省参数的值如果没有传入,则取默认值
8)不定长参数:
有时可能需要一个函数能处理比当初声明时更多的参数, 这些参数叫做不定长参数,声明时不会命名。
加了星号(*)的变量args会存放所有未命名的变量参数,args为元组
而加**的变量kwargs会存放命名参数,即形如key=value的参数, kwargs为字典.
如果很多个值都是不定长参数,那么这种情况下,可以将缺省参数放到 *args的后面, 但如果有(**kwargs)的话,**kwargs必须是最后的
9)拆包时要注意,需要拆的数据的个数要与变量的个数相同,否则程序会异常
除了对元组拆包之外,还可以对列表、字典等拆包
10)引用
在python中,值是靠引用来传递来的。
我们可以用id()来判断两个变量是否为同一个值的引用。 我们可以将id值理解为那块内存的地址标示
Python中函数参数是引用传递(注意不是值传递)
对于不可变类型,因变量不能修改,所以运算不会影响到变量自身
而对于可变类型来说,函数体中的运算有可能会更改传入的参数变量
11)可变类型有:
列表、字典、集合
不可变类型有:
数字、字符串、元组
3、函数三
1)递归:函数在内部不调用其它的函数,而是自己本身的话,这个函数就是递归函数
2)匿名函数:用lambda关键词能创建小型匿名函数
3)列表推导式:所谓的列表推导式,就是指的轻量级循环创建列表
4)列表、集合、元祖转换可以实现去重
4、文件的相关操作
1)使用文件的目的:就是把一些存储存放起来,可以让程序下一次执行的时候直接使用,而不必 重新制作一份,省时省力
2)文件的打开和关闭:
这里是引用变量 = open(文件名,操作方法) 打开文件
变量.close() 关闭文件
3)文件的读和写
<1>写数据(write)
<2>读数据(read)
< 3>读数据(readlines) readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素
<4>读数据(readline)只读取一行
4)文件与文件夹的相关操作
1. 文件重命名
os模块中的rename()可以完成对文件的重命名操作
rename(需要修改的文件名, 新的文件名)
例如:
import os
os.rename("毕业论文.txt", "毕业论文-最终版.txt")
2.删除文件
os模块中的remove()可以完成对文件的删除操作
remove(待删除的文件名)
例如:
import os
os.remove("毕业论文.txt")
3.创建文件夹
import os
os.mkdir("张三")
- 获取当前目录
import os
print(os.getcwd())
- 改变默认目录
import os
os.chdir("../")
- 获取目录列表
import os
Print(os.listdir("./"))
- 删除文件夹
import os
os.rmdir("张三")