一 列表
1 定义: 在[]内,可以存放多个任意类型的值,并以逗号隔开。
一般用于存放学生的爱好,课堂的周期等等...
#定义一个学生列表,可存放多个学生 #list([\'dhevvs\', \'efdsa\', \'thjff\', \'trsv\']) students = [\'dhevvs\', \'efdsa\', \'thjff\', \'trsv\'] print(students[1]) # efdsa student_info = [\'er\', 84, \'male\', [\'泡8\', \'喝9\']] # 取er同学的所有爱好 print(student_info[3]) # 取er同学的第二个爱好 print(student_info[3][1])
2 优先掌握的操作:
# 1、按索引存取值(正向存取+反向存取):即可存也可以取 print(student_info[-2]) # male # 2、切片(顾头不顾尾,步长) print(student_info[0:4:2]) # [\'er\', \'male\'] # 3、长度 print(len(student_info)) # 4 # 4、成员运算in和not in print(\'er\' in student_info) # True print(\'er\' not in student_info) # False # 5、追加 student_info = [\'er\', 84, \'male\', [\'泡8\', \'喝9\']] # 在student_info列表末尾追加一个值 student_info.append(\'xixi\') print(student_info) # 6、删除 # 删除列表中索引为2的值 del student_info[2] print(student_info) # 7、循环 for student in student_info: print(student)
3 需要掌握的操作:
student_info = [\'killer\', 95, \'female\', [\'gawu\', \'hanmai\'], 95] # 1.index 获取列表中某个值的索引 print(student_info.index(95)) # 1 # 2.count 获取列表中某个值的数量 print(student_info.count(95)) # 2 # 3.取值,默认取列表中最后一个值,类似删除 # 若pop()括号中写了索引,则取索引对应的值 student_info.pop() print(student_info) # 取出列表中索引为2的值,并赋值给sex变量名 sex = student_info.pop(2) print(sex) print(student_info) student_info = [\'miller\', 95, \'female\', [\'xx\', \'hh\'], 95] # 4.移除,把列表中的某个值的第一个值移除 student_info.remove(95) print(student_info) # [\'miller\', \'female\', [\'xx\', \'hjh\'], 95] name = student_info.remove(\'miller\') print(name) # None print(student_info) # [\'female\', [\'xx\', \'hh\'], 95] # 5.插入值 student_info = [\'jun\', 95, \'female\', [\'xx\', \'hh\'], 95] # 在student_info中,索引为3的位置插入“合肥学院” student_info.insert(3, \'合肥学院\') # print(student_info) # 6.extend 合并列表 student_info1 = [\'jun\', 95, \'female\', [\'xx\', \'hh\'], 95] student_info2 = [\'miller\', 95, \'female\', [\'xx\', \'hh\'], 95] # 把student_info2所有的值插入student_info1内 student_info1.extend(student_info2) print(student_info1)
二 元组数据类型
1 定义:
# tuple((1, 2, 3, \'五\', \'六\')) tuple1 = (1, 2, 3, \'五\', \'六\') print(tuple1) # (1, 2, 3, \'五\', \'六\')
2 优先掌握的操作:
# 1、按索引取值(正向取+反向取):只能取 print(tuple1[2]) # 3 # 2、切片(顾头不顾尾,步长) # 从0开始切片到5-1, 步长为3 print(tuple1[0:5:3]) # (1, \'五\') # 3、长度 print(len(tuple1)) # 5 # 4、成员运算in和not in print(1 in tuple1) # True print(1 not in tuple1) # False # 5、循环 for line in tuple1: # print(line) # print默认end参数是\n print(line, end=\'_\')
三 可变数据类型和不可变数据类型
1 不可变类型:
变量的值修改后,内存地址一定不一样。
数字类型
int
float
字符串类型
str
元组类型
tuple
2 可变类型:
列表类型
list
字典类型
dict
3 举例说明
#不可变类型 # int number = 100 print(id(number)) # 1434810944 number = 111 print(id(number)) # 1434811296 # float sal = 1.0 print(id(sal)) # 2771339842064 sal = 2.0 print(id(sal)) # 2771339841896 str1 = \'hello python!\' print(id(str1)) # 1975751484528 str2 = str1.replace(\'hello\', \'like\') print(id(str2)) # 1975751484400 # 可变类型: # 列表 list1 = [1, 2, 3] list2 = list1 list1.append(4) # list1与list2指向的是同一份内存地址 print(id(list1)) # 2090131662408 print(id(list2)) # 2090131662408 print(list1) # [1, 2, 3, 4] print(list2) # [1, 2, 3, 4]
四 字典类型
1 作用:
在{}内,以逗号隔开可存放多个值,以key-value存取,取值速度快。
2 定义:
key必须是不可变类型,value可以是任意类型
dict1 = dict({\'age\': 26, \'name\': \'monika\'})
dict1 = {\'age\': 26, \'name\': \'monika\'}
print(dict1) # {\'age\': 26, \'name\': \'monika\'}
print(type(dict1)) # <class \'dict\'>
#取值,字典名 + [],括号内写值对应的key
print(dict1[\'age\'])
3 优先掌握的操作:
#1、按key存取值:可存可取 #存一个 level: 0的值到dict1字典中 dict1[\'level\'] = 0 print(dict1) # {\'age\': 26, \'name\': \'tank\', \'level\': 0} print(dict1[\'name\']) # moniks # 2、长度len print(len(dict1)) # 3、成员运算in和not in 只判断字典中的key print(\'name\' in dict1) # True print(\'monika\' in dict1) # False print(\'monika\' not in dict1) # True # 4、删除 del dict1[\'level\'] print(dict1) # {\'age\': 26, \'name\': \'monika\'} # 5、键keys(),值values(),键值对items() # 得到字典中所有key print(dict1.keys()) # 得到字典中所有值values print(dict1.values()) # 得到字典中所有items print(dict1.items())
#6、循环 #循环遍历字典中所有的key for key in dict1: print(key) print(dict1[key])
# get dict1 = {\'age\': 18, \'name\': \'monika\'} print(dict1.get(\'age\'))# 18 # []取值print(dict1[\'sex\']) # KeyError: \'sex\' # get取值 print(dict1.get(\'sex\')) # None # 若找不到sex,为其设置一个默认值 print(dict1.get(\'sex\', \'male\'))
五 流程控制
1 if 判断:
语法:
if 判断条件:
# 若条件成立,则执行此处代码
逻辑代码
elif 判断条件:
# 若条件成立,则执行此处代码
逻辑代码
else:
# 若以上判断都不成立,则执行此处代码
逻辑代码
# 判断两数大小 x = 10 y = 20 z = 30 # 缩进快捷键,tab往右移动四个空格,shift + tab 往左移动四个空格 if x > y: print(x) elif z > y: print(z) else: print(y)
2 while循环
语法:
while 条件判断:
# 成立执行此处代码
逻辑代码
break # 跳出本层循环
continue # 结束本次循环,进入下一次循环
str1 = \'monika\' # while循环 while True: name = input(\'请输入猜测的字符: \').strip() if name == \'monika\': print(\'tank success!\') break print(\'请重新输入! \') # 限制循环次数 str1 = monika\' # 初始值 num = 0 # 0 1 2 3 # while循环 while num < 3: name = input(\'请输入猜测的字符: \').strip() if name == \'monika\': print(\'tank success!\') break print(\'请重新输入!\') num += 1
六 文件处理
1、 open() # 打开文件
写文件
wt: 写文本
读文件
rt: 读文本
追加写文件
at: 追加文本
注意: 必须指定字符编码,以什么方式写就得以什么方式打开。 如: utf-8
2、执行python文件的过程:
1.先启动python解释器,加载到内存中。
2.把写好的python文件加载到解释器中。
3.检测python语法,执行代码。
SyntaxError: 语法错误!
打开文件会产生两种资源:
1.python程序
2.操作系统打开文件
3、写文本文件
参数一: 文件的绝对路径
参数二: mode 操作文件的模式
参数三: encoding 指定的字符编码
f = open(\'file.txt\', mode=\'wt\', encoding=\'utf-8\') f.write(\'Hello\') f.close() # 关闭操作系统文件资源
4、读文本文件 r == rt
f = open(\'file.txt\', \'r\', encoding=\'utf-8\') print(f.read()) f.close()
5、追加写文本文件
a = open(\'file.txt\', \'a\', encoding=\'utf-8\') a.write(\'\n 合肥学院\') a.close()
七 文件处理之上下文管理
with open() as f "句柄"
# 写 with open(\'file1.txt\', \'w\', encoding=\'utf-8\') as f: f.write(\'墨菲定律\') # 读 with open(\'file1.txt\', \'r\', encoding=\'utf-8\') as f: res = f.read() print(res) # 追加 with open(\'file1.txt\', \'a\', encoding=\'utf-8\') as f: f.write(\'围城\') # f.close()
八 对图片、音频、视频读写
rb模式,读取二进制,不需要指定字符编码
# 读取相片cxk.jpg with open(\'cxk.jpg\', \'rb\') as f: res = f.read() print(res) jpg = res # 把cxk.jpg的二进制流写入cxk_copy.jpg文件中 with open(\'cxk_copy1.jpg\', \'wb\') as f_w: f_w.write(jpg)
with 管理多个文件
# 通过with来管理open打开的两个文件句柄f_r,f_w with open(\'cxk.jpg\', \'rb\') as f_r, open(\'cxk_copy2.jpg\', \'wb\') as f_w: # 通过f_r句柄把图片的二进制流读取出来 res = f_r.read() # 通过f_w句柄把图片的二进制流写入cxk_copy.jpg文件中 f_w.write(res)
九 函数基础
1、函数定义形式
def 函数名(参数1, 参数2...):
"""注释: 声明函数"""
逻辑代码
return 返回值
注意:
def: defind 定义。
函数名: 必须看其名知其意。
(): 接收外部传入的参数。
注释: 用来声明函数的作用。
return: 返回给调用者的值。
定义函数的三种形式:
1.无参函数
不需要接收外部传入的参数。
2.有参函数
需要接收外部传入的参数。
3.空函数
pass
2、函数调用:
函数名 + () 调用
3、无参函数
def login(): user = input(\'请输入用户名\').strip() pwd = input(\'请输入密码\').strip() if user == \'monika\' and pwd == \'123\': print(\'login successful!\') else: print(\'login error!\') # 函数的内存地址 print(login) # 函数调用 login()
4、有参函数
# username,password 用来接收外部传入的值 def login(username, password): user = input(\'请输入用户名\').strip() pwd = input(\'请输入密码\').strip() if user == username and pwd == password: print(\'login successful!\') else: print(\'login error!\') # 函数调用 # 若函数在定义时需要接收参数,调用者必须为其穿传参 login(\'monika\', \'123\')
5、空函数
ATM:
1.登录
2.注册
3.提现
4.取款
5.转账
6.还款
# 登录功能 def login(): # 代表什么都不做 pass # 注册功能 def register(): # 代表什么都不做 pass # 还款功能 def repay(): pass
6、函数的参数:
# 在定义阶段: x, y称之为形参。 def func(x, y): # x, y print(x, y) # # 在调用阶段: 10, 100 称之为实参。 func(10, 100) # 位置参数: # 位置形参 # 位置实参 # 必须按照位置一一传参。 # 在定义阶段: 位置形参 def func(x, y): # x, y print(x, y) # 在调用阶段: 10, 100 称位置实参。 func(10, 100) # 10 100 # 关键字参数: # 关键字实参 # 按照关键字传参。 # 位置形参x, y def func(x, y): print(x, y) # 在调用阶段: x=10, y=100称之为关键字参数。 func(y=111, x=10) # 10 111 # 不能少传 func(y=111) # 报错TypeError # 不能多传 func(y=111, x=222, z=\'333\') # 报错TypeError # 默认参数: # 在定义阶段,为参数设置默认值 def foo(x=10, y=20): print(x, y) # 不传参,则使用默认参数 foo() # 传参,使用传入的参数 foo(200, 300)
7、函数的嵌套定义:
在函数内部定义函数。
8、函数对象:
函数的内存地址称之为函数对象。
9、函数的名称空间:
内置:
python解析器自带的都称之为"内置名称空间"。
全局:
所有顶着头写的变量、函数...都称之为"全名称空间"。
局部:
在函数内部定义的,都称之为"局部名称空间"。
名称空间加载顺序:
内置 ---> 全局 ---> 局部
名称空间查找顺序:
局部 ---> 全局 ---> 内置
# 函数的嵌套定义 def func1(): print(\'from func1...\') def func2(): print(\'from func2...\') # 函数对象 print(func1) def f1(): pass def f2(): pass dic1 = {\'1\': f1, \'2\': f2} choice = input(\'请选择功能编号: \') if choice == \'1\': print(dic1[choice]) dic1[choice]() elif choice == \'2\': print(dic1[choice]) dic1[choice]() # 名称空间 # 函数的嵌套定义 def func1(): # x = 20 print(\'from func1...\') print(x) # 报错 x = 30 def func2(): print(\'from func2...\') func1()