天数:第八天
时间:2023年12月22日
内容:
- 模块 python中最高级的代码组成单元(代码 + 多种封装函数) 回顾:函数是实现某一个单独操作
- 例:有一个数学模块,可以实现最大值,最小值,比大小等等。 但是如果用函数实现的话,很难操作,因为不可能写很多方法在一个函数里面
- 通俗意义:实现一个大业务的工具包(比如是处理人工智能的业务,处理图像的业务),用的时候导入就行了,也称为 包 或 库
- 使用场景举例: 你现在发明了一个手机,但是你想让他有拍照功能,此时只需要导入一个拍照的包即可;我想让他有电池省电功能,此时只需要导入一个省电功能的包即可;需要什么模块,导入就行
- 用法:
- 引入模块: inport 模块名 给模块取别名: import 模块名 as 别名
- 引入复杂模块: from 模块名 import 子模块
- 查找模块: 在python安装的Lib文件中:
- 解析模块:
- 1. 在import 中看到很多引入模块,很多包
- 2. 看到random模块里有个列表,是random模块的不同用法名称,通过调用就能直接使用 大写的变量名是个常数用法
- 3. random模块中的函数,对应着列表,并且看函数能知道这个函数是怎么写的
- python文件引入和main函数
- 场景:我和团队做了个项目(忽略清晨mp3和循环练习),每个人做不同的业务,此时相互之间要导入代码
- 团队的模块是:图1。 我自己的模块是:图2(我要用团队的func1())
- 执行我的代码,发现默认语句会执行: 但是我们只想要func1() 的方法,不要“我是默认语句”
- 写一个main方法,和if方法 解决 把团队默认执行的代码放里面
- 模块分类
- 内置模块: python源码中内置,可直接引入使用
- 第三方模块:有第三方开发,需要先下载才能引入使用
- 内置模块random
- 指定区间的随机整数 random.randint(1,6)
- 指定区间的随机浮点数 random.uniform(1,6)
- 指定列表内的随机数 random.choice([1,45,65,8,75,32,4,2,5,6,8])
- 0到1区间的随机浮点数 random.random()
- 内置模块time
- 时间戳(数值是当前时间举例1970年元旦0时的秒数): x = time. time() 是独一无二的
- 本地时间字符串 x = time . localtime() 得出的结果抽象, 要加上方法: time . strftime( "%Y - %m - % d --------% H : % M : %S" , x ) strftime()方法是一个转换localtime的方法 注意加“%”,注意年月日要大写 Y,m和d小写,时分秒中 H ,M , S都大写,中间加“:”
- 程序休眠 x = time . sleep(秒数 ) 可用来倒计时(while 每次循环中休眠1次)
- 练习:倒计时
-
import time i = 10 while i <= 10: print("倒计时:", i) time.sleep(1) i -= 1 if i < 0: break
- 内置模块datetime (type是'datetime . datetime ')
- 指定时间 datetime . datetime( 2018 , 5, 4, 5, 35 , 45) 获取指定时间: 2018-05-04 05: 35: 45
- 日期转字符串 配合时间对象 . strftime ("%Y年 - %m月 - % d日 % H : % M : %S")
- 字符串转日期(格式要一致) t2 = "2023/12/22 16:34:13" t3 = datetime . datetime . striptime (t2 , "%Y / %m / % d % H : % M : %S" )
- 内置模块urllib (爬虫模块)
- 爬虫:爬取互联网数据程序 专业说法: urllib 模块构置一个请求,能够拿到服务器响应的信息
- 例子:把淘宝网售卖连衣裙的前一百页所有商品数据爬到程序里面,然后识别出每一个商品的价格和销量信息,最终经过一些处理,得到我们想要的信息 如果手动去找这些,太麻烦了
- 引入方法: from urllib import request
- 这与random等模块不一样,原因是urllib 是一个文件,里面还有不同模块
- 步骤:
- url = "http://www. baidu. com " # 要完整的网址
- data = request.urlopen(url).read() # 发送请求并打开相应的url并读取数据
- print (type(data)) # 爬取的内容是二进制
- print (data . decode() ) # 对二进制转换成字符
- 练习(并且复习文件读写方法内容):
-
from urllib import request url = "http://www.baidu.com" data = request.urlopen(url).read() # print(data.decode()) #练习:把读取到的保存在本地 with open(r"C:\Users\gw\OneDrive\桌面\python\baidu爬取.html", "wb") as file2 : data2 = file2.write(data) print(data2)
- 第三方模块
- 第三方开发,需要先下载才能引入使用(为不同行业的不同业务提供解决方案)
- 文件位置:在python安装的site - packages文件中
- 举例:
- pymysql 链接MySQL数据库
- requests 爬虫模块
- numpy 科学计算模块
- pyemail 邮箱处理模块
- pygame 游戏开发模块
- 第三方模块安装4个方法(第三方模块安装失败率高,多尝试几种方法)(写了个word文档,列出下列4个方法详细操作: 第三方模块下载方法. docx)
- 法1:使用pip命令 (用来下载第三方模块的工具)
- 法2:网站下载: https://pypi.python.org
- 法3:清华镜像pip命令
- 法4:在pycharm中下载