Python批量给excel文件加密的操作教程

 更新时间:2025年07月25日 10:51:55   作者:阿黎逸阳  
有时候我们需要定期给公司外部发邮件,在自动化发邮件的时候需要对文件进行加密传输,本文和你一起来探索用python给单个文件和批量文件加密,需要的朋友可以参考下

一、安装pypiwin32包

调用win32com.client,需先要安装pypiwin32包。打开cmd,安装语句如下:

pip install pypiwin32

若安装成功,会显示结果如下:  

二、定义给excel加密的函数

我们先定义一个给单个excel加密的函数,具体代码如下:

import win32com.client

#excel加密函数
def pwd_xlsx(old_filename, new_filename, pwd_str, pw_str=''):
    '''
    old_filename:旧文件名 
    new_filename:新文件名
    pwd_str:保存的新文件密码
    pw_str:打开文件密码,若无访问密码,则设为''
    '''    
    xcl = win32com.client.Dispatch("Excel.Application")
    wb = xcl.Workbooks.Open(old_filename, False, False, None, pw_str)
    xcl.DisplayAlerts = False
    #关闭显示告警对话框
    wb.SaveAs(new_filename, None, pwd_str, '')
    #保存时可设置访问密码
    xcl.Quit()

主要功能是输入旧文件,生成新文件,并对新文件加密。

三、给单个excel加密

在批量加密之前,先调用上一节的函数对单个文件进行加密。具体代码如下:

filename = "F:\\公众号\\71.excel自动加密\\train_u6lujuX_CVtuZ9i.csv"
pwd_xlsx(filename,filename, '1111')
# 三个参数:待加密文件,加密后名称,密码

得到结果:  

从上述pwd_xlsx函数调用语句可知,待加密文件和加密后文件是同一个,且设置的文件密码是1111(密码可根据需要自行设置)。即打开原始文件,保存新文件并加密。由于新文件和原始文件同名,实际是用加密后的新文件覆盖了原始文件。

注意1: 我尝试用os.chdir函数定义存储原始文件的文件夹,在pwd_xlsx函数中只放文件名,结果报错。

注意2: 该函数对excel文件可以加密,若输入的是csv文件,虽然不会报错,但是生成的文件并未加密。

若想加密后的文件不覆盖原始文件,具体代码如下:

old_filename = "F:\\公众号\\71.excel自动加密\\date2.xlsx"
new_filename = "F:\\公众号\\71.excel自动加密\\date2_m.xlsx"
pwd_xlsx(old_filename, new_filename, '123')
# 三个参数:待加密文件,加密后名称,密码

得到结果:  

四、批量给excel加密

首先把需要加密的文件放到一个文件夹中,应用如下程序可以获取该文件夹中的所有文件名称。

import os

folder_path = "F:\\公众号\\71.excel自动加密\\批量加密"
#文件夹路径
file_list = os.listdir(folder_path)
#获取文件夹中所有文件的文件名
for file_name in file_list:
    print(file_name)
    #打印文件夹中的文件名

得到结果:

pl_date1.xlsx
pl_date1_m.xlsx
pl_date2.xlsx
pl_date3.xlsx
pl_date4.xlsx
pl_date5.xlsx

原始文件夹内容如下:  

可以发现两者是一致的。接着调整一下上述代码,生成原始文件路径和名称,以及新文件路径和名称,并批量调用加密函数,生成加密文件,具体代码如下: 

import os

folder_path = "F:\\公众号\\71.excel自动加密\\批量加密"
#文件夹路径
file_list = os.listdir(folder_path)
#获取文件夹中所有文件的文件名
for file_name in file_list:
    old_filename = folder_path + '\\' + file_name
    #原始文件
    new_filename = old_filename.replace('.xlsx', '_m.xlsx')
    #新加密文件
    print(old_filename)
    print(new_filename)
    pwd_xlsx(old_filename, new_filename, '123')
    #调用加密函数对原始文件进行加密并生成新文件,文件密码123

得到结果:

至此,Python中批量给excel文件加密已讲解完毕,感兴趣的朋友可以自己跟着代码尝试一遍图片。

以上就是Python批量给excel文件加密的操作教程的详细内容,更多关于Python excel文件加密的资料请关注脚本之家其它相关文章!

相关文章

  • 基于Python实现迪杰斯特拉和弗洛伊德算法

    基于Python实现迪杰斯特拉和弗洛伊德算法

    这篇文章主要为大家详细介绍了基于Python实现迪杰斯特拉和弗洛伊德算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • 浅析使用Python搭建http服务器

    浅析使用Python搭建http服务器

    这篇文章主要介绍了使用Python搭建http服务器,本文通过代码实例相结合给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • pymysql 开启调试模式的实现

    pymysql 开启调试模式的实现

    这篇文章主要介绍了pymysql 开启调试模式的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • Python算法之栈(stack)的实现

    Python算法之栈(stack)的实现

    这篇文章主要介绍了Python算法之栈(stack)的实现,非常实用,需要的朋友可以参考下
    2014-08-08
  • Python生成数字图片代码分享

    Python生成数字图片代码分享

    这篇文章主要介绍了Python生成数字图片代码分享,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • PyTorch中的padding(边缘填充)操作方式

    PyTorch中的padding(边缘填充)操作方式

    今天小编就为大家分享一篇PyTorch中的padding(边缘填充)操作方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • Python将博客内容html导出为Markdown格式

    Python将博客内容html导出为Markdown格式

    Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转换为Markdown文件
    2025-04-04
  • 使用Python爬虫框架获取HTML网页中指定区域的数据

    使用Python爬虫框架获取HTML网页中指定区域的数据

    在当今互联网时代,数据已经成为了一种宝贵的资源,无论是进行市场分析、舆情监控,还是进行学术研究,获取网页中的数据都是一个非常重要的步骤,Python提供了多种爬虫框架来帮助我们高效地获取网页数据,本文将详细介绍如何使用Python爬虫框架来获取HTML网页中指定区域的数据
    2025-03-03
  • Python使用sklearn库实现的各种分类算法简单应用小结

    Python使用sklearn库实现的各种分类算法简单应用小结

    这篇文章主要介绍了Python使用sklearn库实现的各种分类算法,结合实例形式分析了Python使用sklearn库实现的KNN、SVM、LR、决策树、随机森林等算法实现技巧,需要的朋友可以参考下
    2019-07-07
  • 利用Python自动化处理PPT样式与结构的解决方案

    利用Python自动化处理PPT样式与结构的解决方案

    PowerPoint(PPT)是职场中常用的办公工具,但手动设计和调整样式往往耗时耗力,本文将介绍一套基于Python的自动化解决方案,通过代码实现提取PPT样式,应用样式到模板和幻灯片增删与复制,需要的朋友可以参考下
    2025-04-04

最新评论