ToB企服应用市场:ToB评测及商务社交产业平台

标题: day11-模块 [打印本页]

作者: 忿忿的泥巴坨    时间: 2024-5-16 11:41
标题: day11-模块
1. 自定义模块

1.1 模块和包
  1. import hashlib
  2. def encrypt(data):
  3.     """ 数据加密 """
  4.     hash_object = hashlib.md5()
  5.     hash_object.update(data.encode('utf-8'))
  6.     return hash_object.hexdigest()
  7. user = input("请输入用户名:")
  8. pwd = input("请输入密码:")
  9. md5_password = encrypt(pwd)
  10. message = "用户名:{},密码:{}".format(user, md5_password)
  11. print(message)
复制代码
在开辟简朴的程序时,使用一个py文件就可以搞定,如果程序比较庞大,需要些10w行代码,此时为了,代码结构清晰,将功能按照某种规则拆分到不同的py文件中,使用时再去导入即可。另外,当其他项目也需要此项目的某些模块时,也可以直接把模块拿过去使用,增加重用性。
如果按照某个规则进行拆分,发现拆分到 commons.py 中函数太多,也可以通过文件夹来进行再次拆分,例如:
  1. ├── commons
  2. │   ├── convert.py
  3. │   ├── page.py
  4. │   └── utils.py
  5. └── run.py
复制代码

在Python中一般对文件和文件的称谓(许多开辟者的平时开辟中也有人都称为模块)
留意:在包(文件夹)中有一个默认内容为空的__init__.py的文件,一般用于形貌当前包的信息(在导入他下面的模块时,也会自动加载)。
1.2 导入

当定义好一个模块或包之后,如果想要使用其中定义的功能,必须要先导入,然后再能使用。
导入,其实就是将模块或包加载的内存中,以后再去内存中去拿就行。
关于导如时的路径:
在Python内部默认设置了一些路径,导入模块或包时,都会按照指定顺序逐一去特定的路径查找。
  1. import sys
  2. print(sys.path)
复制代码
想要导入任意的模块和包,都必须写在如下路径下,才能被找到。
也可以自动手动在sys.path中添加指定路径,然后再导入可以,例如:
  1. import sys
  2. sys.path.append("路径A")
  3. import xxxxx  # 导入路径A下的一个xxxxx.py文件
复制代码
关于导入的方式:
导入本质上是将某个文件中的内容先加载到内存中,然后再去内存中拿过来使用。而在Python开辟中常用的导入的方式有2类方式,每类方式都也多种情况。
1.3 相对导入

在导入模块时,对于 from xx import xx这种模式,还支持相对到导入。例如:

切记,相对导入只能用在包中的py文件中(即:嵌套在文件中的py文件才可以使用,项目根目录下无法使用)。

1.4 导入别名

如果项目中导入 成员/模块/包 有重名,那么后导入的会覆盖之前导入,为了避免这种情况的发生,Python支持重命名,即:
  1. from xxx.xxx import xx as xo
  2. import x1.x2 as pg
复制代码
除此之外,有了as的存在,让 import xx.xxx.xxxx.xxx 在调用执行时,会更加简朴(不常用,了解即可)。
1.5 主文件

主文件,其实就是在程序执行的入口文件,例如:
  1. ├── commons
  2. │   ├── __init__.py
  3. │   ├── convert.py
  4. │   ├── page.py
  5. │   ├── tencent
  6. │   │   ├── __init__.py
  7. │   │   ├── sms.py
  8. │   │   └── wechat.py
  9. │   └── utils.py
  10. ├── many.py
  11. └── run.py
复制代码
我们通常是执行 run.py 去运行程序,其他的py文件都是一些功能代码。当我们去执行一个文件时,文件内部的 __name__变量的值为 __main__,所以,主文件常常会看到:
  1. import many
  2. from commons import page
  3. from commons import utils
  4. def start():
  5.     v1 = many.show()
  6.     v2 = page.pagination()
  7.     v3 = utils.encrypt()
  8. if __name__ == '__main__':
  9.     start()
复制代码
只有是以主文件的形式运行此脚本时start函数才会执行,被导入时则不会被执行。
小结

2. 第三方模块

Python内部提供的模块有限,所以在平时在开辟的过程中,常常会使用第三方模块。
而第三方模块必须要先安装才能可以使用,下面介绍常见的3中安装第三方模块的方式。
其实,使用第三方模块的行为就是去用别人写好并开源出来的py代码,这样自己拿来就用,不必重复造轮子了。。。。
2.1 pip(最常用)

这是Python中最最最常用的安装第三方模块的方式。
pip其实是一个第三方模块包管理工具,默认安装Python解释器时自动会安装,默认目录:
  1. MAC系统,即:Python安装路径的bin目录下
  2.         /Library/Frameworks/Python.framework/Versions/3.9/bin/pip3
  3.         /Library/Frameworks/Python.framework/Versions/3.9/bin/pip3.9
  4.        
  5. Windows系统,即:Python安装路径的scripts目录下
  6.         C:\Python39\Scripts\pip3.exe
  7.         C:\Python39\Scripts\pip3.9.exe
复制代码
提示:为了方便在终端运行pip管理工具,我们也会把它地点的路径添加到系统环境变量中。
  1. pip3 install 模块名称
复制代码
如果你的电脑上某个写情况没有找到pip,也可以自己手动安装:
使用pip去安装第三方模块也非常简朴,只需要在自己终端执行:pip install 模块名称 即可。


默认安装的是最新的版本,如果想要指定版本:
  1. pip3 install 模块名称==版本
  2. 例如:
  3. pip3 install django==2.2
复制代码
2.1.1 pip更新

上图的黄色字体提示:现在我电脑上的pip是20.2.3版本,最新的是 20.3.3 版本,如果想要升级为最新的版本,可以在终端执行他提示的命令:
  1. /Library/Frameworks/Python.framework/Versions/3.9/bin/python3.9 -m pip install --upgrade pip
复制代码
留意:根据自己电脑的提示命令去执行,不要用我这里的提示命令哈。
2.1.2 豆瓣源

pip默认是去 https://pypi.org 去下载第三方模块(本质上就是别人写好的py代码),国外的网站速度会比较慢,为了加速可以使用国内的豆瓣源。
写在最后,也还有其他的源可供选择(豆瓣应用广泛)。
  1. 阿里云:http://mirrors.aliyun.com/pypi/simple/
  2. 中国科技大学:https://pypi.mirrors.ustc.edu.cn/simple/
  3. 清华大学:https://pypi.tuna.tsinghua.edu.cn/simple/
  4. 中国科学技术大学:http://pypi.mirrors.ustc.edu.cn/simple/
复制代码
2.2 源码

如果要安装的模块在pypi.org中不存在 或 因特别缘故原由无法通过pip install 安装时,可以直接下载源码,然后基于源码安装,例如:


2.3 wheel

wheel是Python的第三方模块包的文件格式的一种,我们也可以基于wheel去安装一些第三方模块。

无论通过什么形式去安装第三方模块,默认模块的安装路径在:
  1. Max系统:
  2.         /Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages
  3. Windows系统:
  4.         C:\Python39\Lib\site-packages\
复制代码
提醒:这个目录在sys.path中,所以我们直接在代码中直接导入下载的第三方包是没问题的。
3.内置模块(一)

Python内置的模块有许多,我们也已经接触了不少相关模块,接下来咱们就来做一些汇总和介绍。
内置模块有许多 & 模块中的功能也非常多,我们是没有办法留意全局给大家讲解,在此我会整理出项目开辟最常用的来进行讲解。
3.1 os
  1. import os
  2. # 1. 获取当前脚本绝对路径
  3. """
  4. abs_path = os.path.abspath(__file__)
  5. print(abs_path)
  6. """
  7. # 2. 获取当前文件的上级目录
  8. """
  9. base_path = os.path.dirname( os.path.dirname(路径) )
  10. print(base_path)
  11. """
  12. # 3. 路径拼接
  13. """
  14. p1 = os.path.join(base_path, 'xx')
  15. print(p1)
  16. p2 = os.path.join(base_path, 'xx', 'oo', 'a1.png')
  17. print(p2)
  18. """
  19. # 4. 判断路径是否存在
  20. """
  21. exists = os.path.exists(p1)
  22. print(exists)
  23. """
  24. # 5. 创建文件夹
  25. """
  26. os.makedirs(路径)
  27. """
  28. """
  29. path = os.path.join(base_path, 'xx', 'oo', 'uuuu')
  30. if not os.path.exists(path):
  31.     os.makedirs(path)
  32. """
  33. # 6. 是否是文件夹
  34. """
  35. file_path = os.path.join(base_path, 'xx', 'oo', 'uuuu.png')
  36. is_dir = os.path.isdir(file_path)
  37. print(is_dir) # False
  38. folder_path = os.path.join(base_path, 'xx', 'oo', 'uuuu')
  39. is_dir = os.path.isdir(folder_path)
  40. print(is_dir) # True
  41. """
  42. # 7. 删除文件或文件夹
  43. """
  44. os.remove("文件路径")
  45. """
  46. """
  47. path = os.path.join(base_path, 'xx')
  48. shutil.rmtree(path)
  49. """
复制代码
  1. import os
  2. """
  3. data = os.listdir("xxxxxxxx")
  4. print(data)
  5. # ['convert.py', '__init__.py', 'page.py', '__pycache__', 'utils.py', 'tencent']
  6. """
  7. """
  8. 要遍历一个文件夹下的所有文件,例如:遍历文件夹下的所有mp4文件
  9. """
  10. data = os.walk("xxxxxxx")
  11. for path, folder_list, file_list in data:
  12.     for file_name in file_list:
  13.         file_abs_path = os.path.join(path, file_name)
  14.         ext = file_abs_path.rsplit(".",1)[-1]
  15.         if ext == "mp4":
  16.             print(file_abs_path)
复制代码
3.2 shutil
  1. import shutil
  2. # 1. 删除文件夹
  3. """
  4. path = os.path.join(base_path, 'xx')
  5. shutil.rmtree(path)
  6. """
  7. # 2. 拷贝文件夹
  8. """
  9. shutil.copytree("xxxxx","xxxx")
  10. """
  11. # 3.拷贝文件
  12. """
  13. shutil.copy("xxxx","xxxxx")
  14. shutil.copy("xxxxx","xxxx")
  15. """
  16. # 4.文件或文件夹重命名
  17. """
  18. shutil.move("xxxx.png","x.png")
  19. shutil.move("/files","/images")
  20. """
  21. # 5. 压缩文件
  22. """
  23. # base_name,压缩后的压缩包文件
  24. # format,压缩的格式,例如:"zip", "tar", "gztar", "bztar", or "xztar".
  25. # root_dir,要压缩的文件夹路径
  26. """
  27. # shutil.make_archive(base_name=r'datafile',format='zip',root_dir=r'files')
  28. # 6. 解压文件
  29. """
  30. # filename,要解压的压缩包文件
  31. # extract_dir,解压的路径
  32. # format,压缩文件格式
  33. """
  34. # shutil.unpack_archive(filename=r'datafile.zip', extract_dir=r'xxxxxx/xo', format='zip')
复制代码
3.3 sys
  1. import sys
  2. # 1. 获取解释器版本
  3. """
  4. print(sys.version)
  5. print(sys.version_info)
  6. print(sys.version_info.major, sys.version_info.minor, sys.version_info.micro)
  7. """
  8. # 2. 导入模块路径
  9. """
  10. print(sys.path)
  11. """
复制代码
  1. import sys
  2. print(sys.argv)
  3. # [
  4. #       'xxxxx/2.接受执行脚本的参数.py'
  5. # ]
  6. # [
  7. #     "2.接受执行脚本的参数.py"
  8. # ]
  9. # ['2.接受执行脚本的参数.py', '127', '999', '666', 'wupeiqi']
  10. # 例如,请实现下载图片的一个工具。
  11. def download_image(url):
  12.     print("下载图片", url)
  13. def run():
  14.     # 接受用户传入的参数
  15.     url_list = sys.argv[1:]
  16.     for url in url_list:
  17.         download_image(url)
  18. if __name__ == '__main__':
  19.     run()
复制代码
3.4 random
  1. import random
  2. # 1. 获取范围内的随机整数
  3. v = random.randint(10, 20)
  4. print(v)
  5. # 2. 获取范围内的随机小数
  6. v = random.uniform(1, 10)
  7. print(v)
  8. # 3. 随机抽取一个元素
  9. v = random.choice([11, 22, 33, 44, 55])
  10. print(v)
  11. # 4. 随机抽取多个元素
  12. v = random.sample([11, 22, 33, 44, 55], 3)
  13. print(v)
  14. # 5. 打乱顺序
  15. data = [1, 2, 3, 4, 5, 6, 7, 8, 9]
  16. random.shuffle(data)
  17. print(data)
复制代码
3.5 hashlib
  1. import hashlib
  2. hash_object = hashlib.md5()
  3. hash_object.update("武沛齐".encode('utf-8'))
  4. result = hash_object.hexdigest()
  5. print(result)
复制代码
  1. import hashlib
  2. hash_object = hashlib.md5("iajfsdunjaksdjfasdfasdf".encode('utf-8'))
  3. hash_object.update("武沛齐".encode('utf-8'))
  4. result = hash_object.hexdigest()
  5. print(result)
复制代码
3.6 configparser

见:day06
3.7 xml

见:day06
总结

作业

  1. from moviepy.editor import VideoFileClip
  2. import os
  3. # 遍历目录下的所有mp4
  4. def get_mp4_hour(file_path):
  5.     total_seconds = 0
  6.     data = os.walk(file_path)
  7.     for path, folder_list, file_list in data:
  8.         for file_name in file_list:
  9.             file_abs_path = os.path.join(path, file_name)
  10.             ext = file_abs_path.rsplit(".", 1)[-1]
  11.             if ext == "mp4":
  12.                 clip = VideoFileClip(file_abs_path)
  13.                 duration = clip.duration
  14.                 total_seconds += duration
  15.     hour = round(total_seconds/60/60, 2)
  16.     return hour
  17. if __name__ == '__main__':
  18.     get_mp4_hour("xxxx")
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4