• Python对excel文件批量加密(GUI选择)


    在实际工作中,遇到了大量excel文件需要加密,以防止check,于是就网上搜集了一些教程,自己简单写了一个

    1. # -*- coding: utf-8 -*-
    2. # --author:valecalida--
    3. from tkinter import filedialog, simpledialog, Tk
    4. from win32com.client import Dispatch
    5. from os import listdir
    6. from time import sleep
    7. def encrypto_excel(old_filename, new_filename, tmp_passwd, passwd_str=''):
    8. excel_tmp = Dispatch("Excel.Application")
    9. wb = excel_tmp.Workbooks.Open(old_filename, False, False, None, passwd_str)
    10. excel_tmp.DisplayAlerts = False
    11. wb.SaveAs(new_filename, None, tmp_passwd, '')
    12. wb.Close()
    13. excel_tmp.Quit()
    14. def get_file_path(data_dir):
    15. filename_sets = listdir(data_dir)
    16. filename = []
    17. for file_name in filename_sets:
    18. file_name_split = file_name.split('.')
    19. if file_name_split[-1] == 'xlsx' or file_name_split[-1] == 'xls':
    20. filename.append(file_name)
    21. return filename
    22. def main():
    23. root = Tk()
    24. root.withdraw()
    25. # filetypes=(("Excel files", "*.xlsx"),("Excel files", ".xls"))
    26. source_folder = filedialog.askdirectory(title='请选择要加密文件所在文件夹') + '/'
    27. file_list = get_file_path(source_folder)
    28. excel_tmp_passwd = simpledialog.askstring(title='密码设置', prompt='请输入想要设置的密码:')
    29. output_folder = filedialog.askdirectory(title='请选择输出另存的文件夹') + '/'
    30. for f_name in file_list:
    31. print("[*] " + f_name + ' 开始加密啦~')
    32. try:
    33. s_f = (source_folder + f_name).replace("/", "\\")
    34. # print(s_f)
    35. o_f = (output_folder + f_name).replace("/", "\\")
    36. # print(o_f)
    37. encrypto_excel(s_f, o_f, excel_tmp_passwd)
    38. print("[+] " + f_name + " 加密完成了,请注意查看哟~")
    39. except Exception as e:
    40. print(str(e) + f_name + '加密失败了,请手动设置')
    41. if __name__ == '__main__':
    42. main()
    43. sleep(3)

    这里主要是三个功能点:

    • 使用tkinter选择输入输出文件夹,输入自己想要设置的密码
    • 遍历选择的源文件夹,然后将所有的excel文件获取到
    • 利用for循环对每个excel文件进行加密

    当然也有一点问题,这个只能加密没有密码的excel文件,如果有密码的话就会提示加密失败,后续再优化吧,下面是运行界面,输入文件夹路径

     密码输入框

    输出文件夹选择

    2022.11.26更新最新版打包exe文件,见:https://download.csdn.net/download/valecalida/87166485

  • 相关阅读:
    卷积神经网络 - 汇聚层
    5G专网在工业场景中的应用及仿真
    spring boot整合常用redis客户端(Jedis、Lettuce、RedisTemplate、Redisson)常见场景解决方案
    Spring介绍
    seccon 2022 quals wp
    移动WEB开发之rem布局--less基础
    linux 内核漏洞利用 ret2dir
    基于SpringCloud和Vue的前后端分离-预约挂号系统
    面试官:我们深入聊聊Java虚拟机吧
    java与es8实战之三:Java API Client有关的知识点串讲
  • 原文地址:https://blog.csdn.net/valecalida/article/details/127712610