字典类型: 作用: 在{}内,可存放多个值,以key-value存取,取值速度快。 定义: key必须是不可变类型,value可以是任意类型 dict1 = dict({'age': 18, 'name': 'tank'}) dict1 = {'age': 18, 'name': 'tank'} print(dict1) # {'age': 18, 'name': 'tank'} print(type(dict1)) # <class 'dict'> # # 取值,字典名 + [],括号内写值对应的key print(dict1['age']) # # 优先掌握的操作: # 1、按key存取值:可存可取 # 存一个 level: 9的值到dict1字典中 dict1['level'] = 9 print(dict1) # {'age': 18, 'name': 'tank', 'level': 9} print(dict1['name']) # tank # 2、长度len # 3、成员运算in和not in 只判断字典中的key print('name' in dict1) # True print('tank' in dict1) # False print('tank' not in dict1) # True # 4、删除 del dict1['level'] print(dict1) # {'age': 18, 'name': 'tank'} # 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': 'tank'} print(dict1.get('age')) # []取值 print(dict1['sex']) # KeyError: 'sex' # get取值 print(dict1.get('sex')) # None # 若找不到sex,为其设置一个默认值 print(dict1.get('sex', 'male')) 不可变类型: 变量的值修改后,内存地址一定不一样。 数字类型 int float 字符串类型 # str # # 元组类型 # tuple # # 可变类型: # 列表类型 # list # # 字典类型 # dict # # ''' # # 不可变类型 # 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)) print(id(list2)) print(list1) print(list2) 二 流程控制: if 判断: 语法: if 判断条件: # 若条件成立,则执行此处代码 逻辑代码 elif 判断条件: # 若条件成立,则执行此处代码 逻辑代码 else: # 若以上判断都不成立,则执行此处代码 逻辑代码 while循环 语法: while 条件判断: # 成立执行此处 逻辑代码 break # 跳出本层循环 continue # 结束本次循环,进入下一次循环 # 判断两数大小 x = 10 y = 20 z = 30 # 缩进快捷键,tab往右移动四个空格,shift + tab 往左移动四个空格 if x > y: print(x) elif z > y: print(z) else: print(y) ''' while循环 语法: while 条件判断: # 成立执行此处 逻辑代码 break # 跳出本层循环 continue # 结束本次循环,进入下一次循环 ''' # str1 = 'tank' # # # while循环 # while True: # name = input('请输入猜测的字符: ').strip() # if name == 'tank': # print('tank success!') # break # # print('请重新输入! ') # 限制循环次数 str1 = 'tank' # 初始值 num = 0 # 0 1 2 3 # while循环 while num < 3: name = input('请输入猜测的字符: ').strip() if name == 'tank': print('tank success!') break print('请重新输入!') num += 1
三 文件处理: open() 写文件 wt: 写文本 读文件 rt: 读文本 追加写文件 at: 追加文本 注意: 必须指定字符编码,以什么方式写 就得以什么方式打开。 如: utf-8 执行python文件的过程: 1.先启动python解释器,加载到内存中。 2.把写好的python文件加载到解释器中。 3.检测python语法,执行代码。 SyntaxError: 语法错误! 打开文件会产生两种资源: 1.python程序 2.操作系统打开文件 文件处理之上下文管理: 1、with可以管理open打开的文件, 会在with执行完毕后自动调用close()关闭文件 with open() 2、with可以管理多个文件 # 写文本文件 # 参数一: 文件的绝对路径 # 参数二: mode 操作文件的模式 # 参数三: encoding 指定的字符编码 f = open('file.txt', mode='wt', encoding='utf-8') f.write('tank') f.close() # 关闭操作系统文件资源 # 读文本文件 r == rt f = open('file.txt', 'r', encoding='utf-8') print(f.read()) f.close() # # # # 追加写文本文件 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.解决代码冗余问题。 2.使代码的结构更清晰。 3.易管理。 函数的使用必须遵循: 先定义,后调用。 函数定义语法: def 函数名(参数1, 参数2...): '''注释: 声明函数''' 逻辑代码 return 返回值 def: defind 定义。 函数名: 必须看其名知其意。 (): 接收外部传入的参数。 注释: 用来声明函数的作用。 return: 返回给调用者的值。 函数调用: 函数名 + () 调用 ''' # # 1.无参函数 def login(): user = input('请输入用户名').strip() pwd = input('请输入密码').strip() if user == 'tank' and pwd == '123': print('login successful!') else: print('login error!') # # # # 函数的内存地址 print(login) # # # # 函数调用 login() # 2.有参函数 # 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('tank', '123') # 3.空函数 ''' ATM: 1.登录 2.注册 3.提现 4.取款 5.转账 6.还款 ''' # # 登录功能 # def login(): # # 代表什么都不做 # pass # # # # 注册功能 # def register(): # # 代表什么都不做 # pass # # # # 还款功能 # def repay(): # pass # ... ''' 函数的参数: ''' # 在定义阶段: 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) ''' 函数的嵌套定义: 在函数内部定义函数。 函数对象: 函数的内存地址称之为函数对象。 函数的名称空间: 内置: 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]() x = 10 # 名称空间 # 函数的嵌套定义 def func1(): # x = 20 print('from func1...') print(x) # 报错 x = 30 def func2(): print('from func2...') func1()
总结:今日内容比较多,也是python的基础。明日就开始讲爬虫了,还有点小期待呢!
转载于:https://www.cnblogs.com/Max-xyh-1228/p/11095185.html