Python写一个一键解压缩工具(解放双手)

项目要求:输入一个文件夹地址后将该文件夹下的所有压缩文件全部解压缩,并且删除解压过后的压缩包

1.项目分析:

第一步:首先得扫描传入文件夹下的所有文件,然后对这些文件进行处理

第二步:将文件夹解压缩并保存到一个同名文件夹下

第三步:删除这个压缩包

本次所要的头文件:os库,shutil库,time库

实现:

1.先正确输入地址

 dizhi变量用input来输入,输入后无论有没有双引号都把他变为没有双引号的地址

if "" in dizhi:
    dizhi=dizhi.strip('"')

2.定义一个扫描函数如下:用os库下的listdir方法来返回该地址文件下的所有文件和目录信息

返回成一个列表,然后对列表遍历用endswith()方法来判断一个zip文件并返回这个文件的绝对地址

def scan_files():
    files=os.listdir(dizhi)
    for f in files:
        if f.endswith('.zip'):
            return dizhi+'\\'+f

3.定义一个解压函数:

        因为unpack_archive的用法是shutil.unpack_archive("要解压的压缩文件", "解压后文件存在哪个位置")所以要先确定存放路径,因为dizhi是大文件名,要想解压缩到当前文件夹直接用dizhi变量即可 组合好了之后先创建这个文件夹然后用unpack_archive方法解压缩即可

def unzip(f):
    folder_name1=f.split('\\')[-1]
    folder_name=folder_name1.split('.')[0]
    target_path=dizhi+'\\'+folder_name
    os.makedirs(target_path)
    shutil.unpack_archive(f,target_path)

4.定义删除压缩包函数:直接用os库下方的remove方法即可完全删除该文件及子文件的所有内容

def delet(f):
    os.remove(f)

5.主函数实现:

因为将这三个函数组合起来每次只能完成一个文件的处理,所以要加一个while循环,在里面用if zipfile=scanf_files()来处理,如果还能够扫出来文件则继续处理,否则退出循环结束程序,count用于记录次数方便知道你一共解压缩了多少个文件

count=0
while True:
    zipfile=scan_files()
    if zipfile:
        unzip(zipfile)
        delet(zipfile)
        count+=1
        print("已完成"+str(count)+'个')
    else:
        print("三秒后将退出程序")
        print('3')
        time.sleep(1)
        print('2')
        time.sleep(1)
        print('1')
        time.sleep(1)
        break

6.通过以上的实现代码部分就完成了,下面把这个py文件打包成一个exe的可执行文件、

首先在pycharm终端输入pip install pyinstaller                    这是安装成功后的样子

然后输入 pyinstaller -F main.py   这个mian是你这个文件的文件名

当出现上图所示的大概内容就说明成功了,然后 找到你这个Py文件所在的文件夹目录,里面会生成一个dist的文件夹,exe文件就在这个文件夹下了,直接运行即可,也可以把这个文件剪切到其他文件夹下也能同样使用

 记住如果你的py文件里用到了input()函数,那么你的可执行文件就要有一个窗口来供你输入

那么打包的时候就不能加上-W ,也就是不能写成pyinstaller -F -W mian.py 

这样会去除windows窗口从而运行文件的时候就会报错

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 好的,这是一份生成多个Excel文档的代码: ``` import openpyxl def generate_excel(file_name_prefix, sheet_name, data, num_files): for i in range(num_files): file_name = f"{file_name_prefix}_{i+1}.xlsx" workbook = openpyxl.Workbook() sheet = workbook.active sheet.title = sheet_name for row_data in data: sheet.append(row_data) workbook.save(filename=file_name) print(f"成功生成了{num_files}个Excel文件!") # 示例数据 data = [ [1, 2, 3], [4, 5, 6], [7, 8, 9] ] # 调用函数生成3个Excel文件 generate_excel("test", "Sheet1", data, 3) ``` 这段代码使用了 `openpyxl` 库,它可以帮助你读Excel文件。该代码定义了一个 `generate_excel` 函数,该函数接受文件名前缀,sheet名称,数据和文件数量等参数,并生成指定数量的Excel文件。 希望这能帮到你! ### 回答2: Python可以使用openpyxl库来操作Excel文档,我们可以利用这个库来一个一键生成多个Excel文档的代码。 首先,需要安装openpyxl库,可以使用以下命令来安装: ``` pip install openpyxl ``` 然后,我们可以按照以下步骤编一键生成多个Excel文档的代码: 1. 导入openpyxl库: ```python import openpyxl ``` 2. 定义一个函数来创建一个Excel文档: ```python def create_excel(filename): workbook = openpyxl.Workbook() sheet = workbook.active sheet.title = "Sheet1" workbook.save(filename) ``` 3. 定义一个函数来批量生成Excel文档: ```python def generate_excel(num): for i in range(num): filename = "excel_" + str(i+1) + ".xlsx" create_excel(filename) ``` 4. 调用`generate_excel`函数来生成多个Excel文档: ```python generate_excel(5) ``` 上述代码将生成名为`excel_1.xlsx`、`excel_2.xlsx`、`excel_3.xlsx`、`excel_4.xlsx`和`excel_5.xlsx`的Excel文档,每个文档都包含一个名为"Sheet1"的工作表。 以上是使用Python一个一键生成多个Excel文档的代码,希望能帮到你! ### 回答3: 使用Python一个一键生成多个Excel文档的代码非常简单。首先,我们需要安装python模块 openpyxl,它可以帮助我们操作Excel文件。 接下来,我们需要定义一个函数,该函数将接收2个参数:要生成的Excel文件的数量和每个文件的名称。代码如下: ```python from openpyxl import Workbook def generate_excel_files(num_files, file_name): for i in range(1, num_files+1): wb = Workbook() # 创建一个新的工作簿 sheet = wb.active # 获取活动工作表 # 向工作表中入数据,这里仅作示例,可以根据需求修改 sheet['A1'] = '姓名' sheet['B1'] = '年龄' sheet['C1'] = '性别' # 将数据保存到指定文件名的Excel文档中 wb.save(file_name + str(i) + '.xlsx') # 调用函数生成10个Excel文件文件名分别为file1.xlsx, file2.xlsx, ..., file10.xlsx generate_excel_files(10, 'file') ``` 上述代码将生成10个Excel文件,每个文件名分别为file1.xlsx, file2.xlsx, ..., file10.xlsx。每个文件中都包含一个默认的工作表,工作表中有3列数据:姓名、年龄和性别。 代码中使用的openpyxl模块提供了许多更高级的功能,例如插入数据、合并单元格等等。您可以根据自己的需求对生成的Excel文件进行进一步的操作和定制化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

业精于勤荒于嬉,行成于思毁于随

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值