python文件自动分类(3)

接上节课内容

但在前面判断文件类型的代码中,我们只使用了小写的文件后缀名去进行匹配。
这样的话,比如像“心动.MP3”这个文件就被分类到了“其他文件”。
那么该怎样对大写的后缀名 .MP3 等进行判断呢?

统一字符串

为了解决这个问题,我们可以对文件后缀名使用 lower() 函数。
lower() 函数可以把字符串中所有的字母全部转换成小写。
本示例中,就将两个示例字符串转换成了小写并使用print输出结果。

sampleStr1 = "NATE".lower()

sampleStr2 = "Drake".lower()

print(sampleStr1)

print(sampleStr2)

对文件后缀名使用lower()函数,修改对文件分类的代码,使“心动.MP3”文件被正确分类。

学习了 lower() 函数后,我们现在把它应用到获取文件后缀名的代码中,将文件后缀名全部转换为小写
转换之后,再使用之前的代码进行判断,“心动.MP3”就能被正确分类了。

# 使用import导入os模块

import os

# 将阿文的下载文件夹路径 /Users/yequ/Downloads 赋值给变量downloadPath

downloadPath = "/Users/yequ/Downloads"

# 使用os.listdir()函数获取该路径下所有的文件(夹),并赋值给变量allItems

allItems = os.listdir(downloadPath)

# 使用for循环遍历所有文件(夹)

for item in allItems:

    # 获取文件后缀名并使用lower()函数转换成小写

    extension = os.path.splitext(item)[1].lower()

    if extension in [".jpg", ".jpeg", ".gif", ".png", ".bmp"]:

        print(f"{item} 图片文件")

    elif extension in [".avi", ".mp4", ".wmv", ".mov", ".flv"]:

        print(f"{item} 视频文件")

    elif extension in [".wav", ".mp3", ".mid", ".ape", ".flac"]:

        print(f"{item} 音频文件")

    elif extension in [".pdf"]:

        print(f"{item} PDF文件")

    elif extension in [".docx", ".doc"]:

        print(f"{item} Word文件")

    elif extension in [".xlsx", ".xls"]:

        print(f"{item} Excel文件")

    elif extension in [".pptx", ".ppt"]:

        print(f"{item} PPT文件")

    else:

        print(f"{item} 其他文件")

完成了文件分类后,要想办法把文件移动到对应的文件夹中
在移动文件之前,我们首先需要确认文件的移动路径
例如,要把某个文件移动到音频文件,就需要确定移动到哪里的音频文件夹中。

合并多个路径

First,我们首先需要确定目标文件夹的路径。
阿文的习惯,是将每一个分类文件夹创建在下载文件夹中。
例如,图片文件夹的路径为:
/Users/yequ/Downloads/图片文件
该路径前半部分为下载文件夹的路径,后半部分为分类文件夹的名字。

Second:在代码中,使用 os.path.join() 函数来拼接每个分类文件夹的路径。该函数需要传入两个参数,将两个参数拼接起来组成目标路径。
例如:需要将某个文件夹保存到电脑的桌面上,文件的名称是音频文件。
桌面的路径为: /Users/Desktop
文件夹名字为:"音频文件"
使用 os.path.join() 就能拼接成文件夹的路径。

该函数在合并时,会根据操作系统的不同,在路径之间添加合适的路径分隔符。

在遍历所有文件(夹)的代码中,定义一个变量targetPath,用来表示准备移动到的文件夹路径。
在每一个分类判断代码内,使用os.path.join()函数拼接出目标文件夹路径并赋值给变量targetPath。
最后使用print输出变量targetPath,查看拼接的结果。

回到问题,我们已经判断了每个文件所属的类别。接下来,使用变量 targetPath 来表示目标文件夹路径。
在每一个分类判断代码内,使用 os.path.join() 函数拼接出目标文件夹路径并赋值给变量 targetPath 。

# 使用import导入os模块

import os

# 将阿文的下载文件夹路径 /Users/yequ/Downloads 赋值给变量downloadPath

downloadPath = "/Users/yequ/Downloads"

# 使用os.listdir()函数获取该路径下所有的文件(夹),并赋值给变量allItems

allItems = os.listdir(downloadPath)

# 使用for循环遍历所有文件(夹)

for item in allItems:

    # 获取文件后缀名

    extension = os.path.splitext(item)[1].lower()

    # 定义一个变量targetPath,用来表示准备移动到的文件夹路径

    targetPath = ""

    if extension in [".jpg", ".jpeg", ".gif", ".png", ".bmp"]:

        # 使用os.path.join()函数拼接路径:图片文件

        targetPath = os.path.join(downloadPath, "图片文件")

    elif extension in [".avi", ".mp4", ".wmv", ".mov", ".flv"]:

        # 使用os.path.join()函数拼接路径:视频文件

        targetPath = os.path.join(downloadPath, "视频文件")

    elif extension in [".wav", ".mp3", ".mid", ".ape", ".flac"]:

        # 使用os.path.join()函数拼接路径:音频文件

        targetPath = os.path.join(downloadPath, "音频文件")

    elif extension in [".pdf"]:

        # 使用os.path.join()函数拼接路径:PDF文件

        targetPath = os.path.join(downloadPath, "PDF文件")

    elif extension in [".docx", ".doc"]:

        # 使用os.path.join()函数拼接路径:Word文件

        targetPath = os.path.join(downloadPath, "Word文件")

    elif extension in [".xlsx", ".xls"]:

        # 使用os.path.join()函数拼接路径:Excel文件

        targetPath = os.path.join(downloadPath, "Excel文件")

    elif extension in [".pptx", ".ppt"]:

        # 使用os.path.join()函数拼接路径:PPT文件

        targetPath = os.path.join(downloadPath, "PPT文件")

    else:

        # 使用os.path.join()函数拼接路径:其他文件

        targetPath = os.path.join(downloadPath, "其他文件")

    # 使用print输出targetPath,查看拼接结果

    print(targetPath)

确定了每个文件需要移动的目标文件夹,那么在移动前还需要确定目标文件夹是否存在
如果目标文件夹不存在,需要先创建文件夹再移动。
例如:心动.mp3 需要移动到音频文件夹中,那么需要先检查 Downloads 文件夹中是否已经创建了音频文件夹。

判断文件是否存在

得到了目标文件夹的路径后,我们可以使用 os.path.exists() 函数来判断该文件夹是否已经存在。
os.path.exists() 函数接受一个路径字符串作为参数,当该路径的文件夹存在时,返回True,不存在时,则返回False。

使用os.path.exists()函数判断目标文件夹是否存在,如果不存在,使用print输出目标路径。

因此,要解决阿文的问题,我们在得到了目标文件夹的路径后,就可以使用 os.path.exists() 函数来判断目标文件夹是否已经存在。
通过 if 判断语句+ not 运算符来判断目标文件夹不存在的情况。

# 使用import导入os模块

import os

# 将阿文的下载文件夹路径 /Users/yequ/Downloads 赋值给变量downloadPath

downloadPath = "/Users/yequ/Downloads"

# 使用os.listdir()函数获取该路径下所有的文件(夹),并赋值给变量allItems

allItems = os.listdir(downloadPath)

# 使用for循环遍历所有文件(夹)

for item in allItems:

    # 获取文件后缀名

    extension = os.path.splitext(item)[1].lower()

    # 定义一个变量targetPath,用来表示准备移动到的文件夹路径

    targetPath = ""

    if extension in [".jpg", ".jpeg", ".gif", ".png", ".bmp"]:

        # 使用os.path.join()函数拼接分类文件夹路径:图片文件

        targetPath = os.path.join(downloadPath, "图片文件")

    elif extension in [".avi", ".mp4", ".wmv", ".mov", ".flv"]:

        # 使用os.path.join()函数拼接分类文件夹路径:视频文件

        targetPath = os.path.join(downloadPath, "视频文件")

    elif extension in [".wav", ".mp3", ".mid", ".ape", ".flac"]:

        # 使用os.path.join()函数拼接分类文件夹路径:音频文件

        targetPath = os.path.join(downloadPath, "音频文件")

    elif extension in [".pdf"]:

        # 使用os.path.join()函数拼接分类文件夹路径:PDF文件

        targetPath = os.path.join(downloadPath, "PDF文件")

    elif extension in [".docx", ".doc"]:

        # 使用os.path.join()函数拼接分类文件夹路径:Word文件

        targetPath = os.path.join(downloadPath, "Word文件")

    elif extension in [".xlsx", ".xls"]:

        # 使用os.path.join()函数拼接分类文件夹路径:Excel文件

        targetPath = os.path.join(downloadPath, "Excel文件")

    elif extension in [".pptx", ".ppt"]:

        # 使用os.path.join()函数拼接分类文件夹路径:PPT文件

        targetPath = os.path.join(downloadPath, "PPT文件")

    else:

        # 使用os.path.join()函数拼接分类文件夹路径:其他文件

        targetPath = os.path.join(downloadPath, "其他文件")

    # 如果目标文件夹不存在,使用print输出目标路径

    if not os.path.exists(targetPath):

        # 使用print输出目标路径

        print(targetPath)

创建文件夹

前面已经讲了利用 os.path.exists() 函数判断文件夹是否存在。
如果文件夹不存在,我们需要先创建文件夹,再移动文件。
创建文件夹可以使用 os.mkdir() 函数:将要创建的文件夹路径作为参数传入函数中即可。

展示

在之前判断目标文件夹是否存在的代码中,加上os.mkdir(targetPath)以创建文件夹。

在之前判断目标文件夹是否存在的代码中,加上 os.mkdir(targetPath) 即可创建所有不存在的文件夹。

# 使用import导入os模块

import os

# 将阿文的下载文件夹路径 /Users/yequ/Downloads 赋值给变量downloadPath

downloadPath = "/Users/yequ/Downloads"

# 使用os.listdir()函数获取该路径下所有的文件(夹),并赋值给变量allItems

allItems = os.listdir(downloadPath)

# 使用for循环遍历所有文件(夹)

for item in allItems:

    # 获取文件后缀名

    extension = os.path.splitext(item)[1].lower()

    # 定义一个变量targetPath,用来表示准备移动到的文件夹路径

    targetPath = ""

    if extension in [".jpg", ".jpeg", ".gif", ".png", ".bmp"]:

        # 使用os.path.join()函数拼接分类文件夹路径:图片文件

        targetPath = os.path.join(downloadPath, "图片文件")

    elif extension in [".avi", ".mp4", ".wmv", ".mov", ".flv"]:

        # 使用os.path.join()函数拼接分类文件夹路径:视频文件

        targetPath = os.path.join(downloadPath, "视频文件")

    elif extension in [".wav", ".mp3", ".mid", ".ape", ".flac"]:

        # 使用os.path.join()函数拼接分类文件夹路径:音频文件

        targetPath = os.path.join(downloadPath, "音频文件")

    elif extension in [".pdf"]:

        # 使用os.path.join()函数拼接分类文件夹路径:PDF文件

        targetPath = os.path.join(downloadPath, "PDF文件")

    elif extension in [".docx", ".doc"]:

        # 使用os.path.join()函数拼接分类文件夹路径:Word文件

        targetPath = os.path.join(downloadPath, "Word文件")

    elif extension in [".xlsx", ".xls"]:

        # 使用os.path.join()函数拼接分类文件夹路径:Excel文件

        targetPath = os.path.join(downloadPath, "Excel文件")

    elif extension in [".pptx", ".ppt"]:

        # 使用os.path.join()函数拼接分类文件夹路径:PPT文件

        targetPath = os.path.join(downloadPath, "PPT文件")

    else:

        # 使用os.path.join()函数拼接分类文件夹路径:其他文件

        targetPath = os.path.join(downloadPath, "其他文件")

    # 如果目标文件夹不存在,使用os.mkdir()函数创建文件夹

    if not os.path.exists(targetPath):

        # 使用os.mkdir()函数创建文件夹

        os.mkdir(targetPath)

 思考一下,这样是否能彻底实现文件自动分类功能

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,为您编写一个文件自动分类工具的代码: ``` import os import shutil def classify_files(src_dir, dst_dir): file_types = {} for filename in os.listdir(src_dir): file_path = os.path.join(src_dir, filename) if os.path.isfile(file_path): file_type = filename.split('.')[-1] if file_type not in file_types: os.makedirs(os.path.join(dst_dir, file_type)) file_types[file_type] = os.path.join(dst_dir, file_type) shutil.move(file_path, os.path.join(file_types[file_type], filename)) src_dir = '/path/to/src' dst_dir = '/path/to/dst' classify_files(src_dir, dst_dir) ``` 该代码会读取`src_dir`目录下的所有文件,并根据文件后缀分类到`dst_dir`目录下。比如,如果有一个名为`example.txt`的文本文件,它会被移动到`dst_dir/txt/`目录下。 希望对您有所帮助! ### 回答2: Python是一种高级编程语言,非常适合用于编写自动化工具。下面是一个用Python编写的文件自动分类工具的示例: 该工具的目标是为指定的文件夹中的文件进行自动分类。用户只需要提供要分类文件夹路径和分类规则,工具就能自动文件按照规则进行分类。 首先,用户需要在源代码中定义分类规则。例如,用户可以使用文件的扩展名作为分类依据,将具有相同扩展名的文件放入同一个文件夹。用户可以通过修改代码中的分类规则来满足个性化的需求。 接下来,工具会遍历指定文件夹中的所有文件。使用Python的os库可以轻松地获取文件夹中的文件列表。然后,工具会根据分类规则将文件移动到相应的文件夹中。使用Python的shutil库可以方便地实现文件的移动操作。 工具还可以对每个文件夹进行计数,以便用户了解每个分类中有多少个文件。可以使用Python的os库来获取文件夹内文件的数量。 最后,工具会生成一个报告,列出分类结果以及每个分类文件的数量。用户可以将报告保存到一个文本文件中。可以使用Python文件操作来创建并写入报告。 使用Python编写这样一个文件自动分类工具,可以帮助用户快速整理和管理文件,提高工作效率。该工具非常灵活,用户可以根据自己的需求进行规则的设置。同时,Python具有简单易学的语法和丰富的库支持,使得编写这样的工具变得轻松高效。 ### 回答3: Python是一种强大且易于使用的编程语言,可以用于编写各种应用程序和工具。对于文件自动分类工具的编写,Python文件操作和字符串处理的功能非常适合。 首先,可以使用Python的os模块来遍历指定文件夹中的所有文件。这样可以获取文件夹下的所有文件的路径。 接下来,可以使用Python的shutil模块来创建新的文件夹,并将文件移动到相应的文件夹中。通过判断文件的扩展名,可以将不同类型的文件分类到不同的文件夹中。例如,可以创建一个名为"图片"的文件夹,将扩展名为".jpg"、".png"和".gif"的文件移动到该文件夹中。同样的原理可以应用于其他类型的文件,如文档、音频和视频等。 另外,为了方便用户使用,可以使用Python的argparse模块来接受用户输入的文件夹路径作为参数。这样用户只需在命令行中输入文件夹路径,即可自动文件分类到相应的文件夹中。同时,可以添加一些错误处理的功能,比如用户输入的文件夹路径不存在或者没有权限访问等。 最后,为了提高用户体验,可以使用Python的tkinter模块或Qt模块等来创建一个用户界面。用户可以通过界面来选择文件夹,并点击一个按钮来开始自动分类的过程。界面还可以显示分类的进度和结果等信息,让用户了解整个过程的运行情况。 综上所述,利用Python编写一个文件自动分类工具是十分可行的。通过利用Python文件操作、字符串处理和GUI库等功能,可以实现一个简单而实用的工具,提高文件管理的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值