模块

1.第三方模块

Python内部提供的模块有限,所以在平时在开发的过程中,经常会使用第三方模块。

而第三方模块必须要先安装才能可以使用,使用第三方模块的行为就是去用别人写好并开源出来的py代码,这样自己拿来就用,不必重复造轮子了。

下面介绍常见的3种安装第三方模块的方式。

1.1pip【最常用】

pip其实是一个第三方模块包管理工具,默认安装Python解释器时自动会安装,默认目录:

Windows系统,即:Python安装路径的scripts目录下
  C:\Python39\Scripts\pip3.exe
  C:\Python39\Scripts\pip3.9.exe

为了方便在终端运行pip管理工具,我们也会把它所在的路径添加到系统环境变量中。

安装第三方模块命令

pip3 install 模块名称

默认安装的是最新的版本,如果想要指定版本:

pip3 install 模块名称==版本

eg:pip3 install django==4.2.0

1.1.1 pip更新

上图的绿色字体提示:目前我电脑上的pip是24.0版本,最新的是 24.1.2 版本,如果想要升级为最新的版本,可以在终端执行他提示的命令:

python.exe -m pip install --upgrade pip

注意:根据自己电脑的提示命令去执行,不要用我这里的提示命令哦。

1.1.2 镜像源

pip默认是去 https://pypi.org 去下载第三方模块(本质上就是别人写好的py代码),国外的网站速度会比较慢,为了加速可以使用国内的镜像源。

  • 一次性使用
    pip install 模块名称  -i  镜像地址
    
  • 永久使用
    配置
    # 在终端执行如下命令
    pip config set global.index-url 镜像地址
    以腾讯源为eg:pip config set global.index-url https://mirrors.cloud.tencent.com/pypi/simple
    # 执行完成后,提示在我的本地文件中写入了豆瓣源,以后再通过pip去安装第三方模块时,就会默认使用豆瓣源了。
    # 自己以后也可以打开文件直接修改源地址。
    
    其实,也还有其他的源可供选择
    清华大学:https://pypi.tuna.tsinghua.edu.cn/simple/
    阿里云:http://mirrors.aliyun.com/pypi/simple/
    中国科学技术大学:http://pypi.mirrors.ustc.edu.cn/simple/
    中国科技大学:https://pypi.mirrors.ustc.edu.cn/simple/ ![]
    

1.2 源码

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

  • 下载requests源码(压缩包zip、tar、tar.gz)并解压。
    下载地址:https://pypi.org/project/requests/#files
    
  • 进入目录
  • 执行编译和安装命令
    python3 setup.py build
    python3 setup.py install
    

2.3 wheel

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

  • 安装wheel格式支持,这样pip再安装第三方模块时,就可以处理wheel格式的文件了。

    pip3.9 install wheel
    
  • 下载第三方的包(wheel格式),例如:https://pypi.org/project/requests/#files


    进入下载目录,在终端基于pip直接安装

but,无论通过什么形式去安装第三方模块,默认模块的安装路径在:

Windows系统:
	C:\Python39\Lib\site-packages\

2.内置模块(一)

Python内置的模块有很多,下面是一些汇总和介绍。

2.1 os

import os

# 1. 获取当前脚本绝对路径
"""
abs_path = os.path.abspath(__file__)
print(abs_path)
"""

# 2. 获取当前文件的上级目录
"""
base_path = os.path.dirname( os.path.dirname(路径) )
print(base_path)
"""

# 3. 路径拼接
"""
p1 = os.path.join(base_path, 'xx')    # 这儿要注意转义错误,通常加上r或者双斜杠来表示
print(p1)

p2 = os.path.join(base_path, 'xx', 'oo', 'a1.png')
print(p2)
"""

# 4. 判断路径是否存在
"""
exists = os.path.exists(p1)
print(exists)
"""

# 5. 创建文件夹
"""
os.makedirs(路径)
"""
"""
path = os.path.join(base_path, 'xx', 'oo', 'uuuu')
if not os.path.exists(path):
    os.makedirs(path)
"""

# 6. 是否是文件夹
"""
file_path = os.path.join(base_path, 'xx', 'oo', 'uuuu.png')
is_dir = os.path.isdir(file_path)
print(is_dir) # False

folder_path = os.path.join(base_path, 'xx', 'oo', 'uuuu')
is_dir = os.path.isdir(folder_path)
print(is_dir) # True

"""

# 7. 删除文件或文件夹
"""
os.remove("文件路径")
"""
"""
path = os.path.join(base_path, 'xx')
shutil.rmtree(path)  # 删除文件夹
"""

  • listdir,查看目录下所有的文件【重要】
  • walk,查看目录下所有的文件(含子孙文件)【重要】
import os

"""
data = os.listdir("路径")
print(data)
# ['convert.py', '__init__.py', 'page.py', '__pycache__', 'utils.py', 'tencent']
"""

"""
要遍历一个文件夹下的所有文件,例如:遍历文件夹下的所有mp4文件
"""

data = os.walk("路径")   #结果是生成器
for path, folder_list, file_list in data:
    for file_name in file_list:
        file_abs_path = os.path.join(path, file_name)
        ext = file_abs_path.rsplit(".",1)[-1]
        if ext == "mp4":
            print(file_abs_path)

2.2 shutil

import shutil

# 1. 删除文件夹
"""
path = os.path.join(base_path, 'xx')
shutil.rmtree(path)
"""

# 2. 拷贝文件夹
"""
shutil.copytree("要拷贝的路径","要放到的路径")
"""

# 3.拷贝文件
"""
shutil.copy("要拷贝的文件","要放到的文件夹或者文件")
"""

# 4.文件或文件夹重命名  用来移动文件或者文件名   把前者移动d
"""
shutil.move("要拷贝的文件","要放到的文件")
shutil.move("要拷贝的文件夹","要拷贝的文件夹")
"""

# 5. 压缩文件
"""
# base_name,压缩后的压缩包文件
# format,压缩的格式,例如:"zip", "tar", "gztar", "bztar", or "xztar".
# root_dir,要压缩的文件夹路径
"""
# shutil.make_archive(base_name=r'datafile',format='zip',root_dir=r'files')


# 6. 解压文件
"""
# filename,要解压的压缩包文件
# extract_dir,解压的路径
# format,压缩文件格式
"""
# shutil.unpack_archive(filename=r'datafile.zip', extract_dir=r'xxxxxx/xo', format='zip')

2.3 sys

import sys

# 1. 获取解释器版本
"""
print(sys.version)
print(sys.version_info)
print(sys.version_info.major, sys.version_info.minor, sys.version_info.micro)
"""

# 2. 导入模块路径
"""
print(sys.path)
"""

2.4 random

import random

# 1. 获取范围内的随机整数
v = random.randint(10, 20)
print(v)

# 2. 获取范围内的随机小数
v = random.uniform(1, 10)
print(v)

# 3. 随机抽取一个元素
v = random.choice([11, 22, 33, 44, 55]) # 这个可以是列表 元组  字符串(可以通过索引获取到值的)
print(v)

# 4. 随机抽取多个元素
v = random.sample([11, 22, 33, 44, 55], 3)  # 后面这个绝对抽取几个数 这个可以是列表 元组  字符串(可以通过索引获取到值的)
print(v)

# 5. 打乱顺序
data = [1, 2, 3, 4, 5, 6, 7, 8, 9]  
random.shuffle(data)   # 打乱原来列表当中的数据
print(data)

2.5 hashlib(加密)

import hashlib

hash_object = hashlib.md5()  # 创建了md5的对象
hash_object.update("fdfd12".encode('utf-8'))  # 传入字节类型的数据(加密的数据)
result = hash_object.hexdigest()
print(result)
import hashlib

hash_object = hashlib.md5("iajfsdunjaksdjfasdfasdf".encode('utf-8'))  # 加盐:加密时加上只有我们知道的字符串
hash_object.update("fdfd12".encode('utf-8')) #将字符串进行加密
result = hash_object.hexdigest()
print(result)
import hashlib
def md5(origin="高涛",salt = "123fsdfsd"):

    hash_objcet = hashlib.md5(salt.encode('utf-8'))
    hash_objcet.update(origin.encode("utf-8"))
    result = hash_objcet.hexdigest()
    return result

result = md5()
print(result)

2.6 configparser

import configparser
#读ini文件一定要写下面的这两行代码
config = configparser.ConfigParser()  # 使用这个模块来读取这个my.ini的配置文件,并将配置文件的内容加载到configparser的cofig中 
config.read('E:\my.ini', encoding='utf-8')

2.7 xml

from xml.etree import ElementTree as ET
# ET去打开xml文件
tree = ET.parse("E:\xo.xml")
posted @ 2024-07-10 13:59  清风拂山岗(小高同学)  阅读(33)  评论(0编辑  收藏  举报