码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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

  • 相关阅读:
    GBase 8c V3.0.0数据类型——序列函数
    学生HTML个人网页作业作品 使用HTML+CSS+JavaScript个人介绍博客网站 web前端课程设计 web前端课程设计代码 web课程设计
    [Tool] Git 使用 与 Git Flow
    浙江大学数据结构MOOC-课后习题-第十讲-排序4 统计工龄
    Python八股文
    SpringMVC如何在web.xml中配置DispatcherServlet呢?
    9.28 - 每日一题 - 408
    图形学学习笔记
    k8s--基础--18.6--存储卷--类型--PVC实践
    【无源谐波滤波器通常用于电力系统中的谐波抑制】用于抑制电力系统谐波的无源谐波滤波器(Simulink实现)
  • 原文地址:https://blog.csdn.net/valecalida/article/details/127712610
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号