使用Python保护或加密Excel文件的7种方法

news2024/12/25 2:00:01

目录

安装Python Excel库

Python 使用文档打开密码保护 Excel 文件

Python 使用文档修改密码保护 Excel 文件

Python 将 Excel 文件标记为最终版本

Python 保护 Excel 工作表

Python 在保护 Excel 工作表的同时允许编辑某些单元格

Python 锁定 Excel 工作表中的特定单元格

Python 锁定 Excel 工作表中的特定行或列


Excel文件通常包含敏感信息,如财务记录、客户数据或专有公式。保护和加密这些文件对于防止未经授权的访问和维护机密性至关重要。在本文中,我们将探讨如何使用Python自动化Excel文件的安全保护和加密过程,确保数据的安全性。主要包括以下主题:

  • 使用文档打开密码保护 Excel 文件
  • 使用文档修改密码保护 Excel 文件
  • 将 Excel 文件标记为最终版本
  • 保护 Excel 工作表
  • 在保护 Excel 工作表的同时允许编辑某些单元格
  • 锁定 Excel 工作表中的特定单元格
  • 锁定Excel 工作表中的特定行或列

安装Python Excel库

在Python中,我们可以使用Spire.XLS for Python库来保护或加密Excel文件。该库提供了多种功能来保护和加密Excel文件,如设置密码、应用工作表保护、将Excel标记为最终版本、锁定单元格、行、列等。

你可以使用以下pip命令从PyPI安装Spire.XLS for Python:

pip install Spire.Xls

如果不清楚如何安装,查看这篇文档:如何在 Windows 中安装 Spire.XLS for Python

Python 使用文档打开密码保护 Excel 文件

文档打开密码的主要作用是限制未经授权的人打开或访问文档。设置了打开密码后,任何人都需要输入正确的密码才能成功打开该Excel文件。

通过使用Spire.XLS for Python提供的Workbook.Protect()方法,可以给Excel文件设置文档打开密码。关键步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.Protect()方法给该Excel文件设置文档打开密码。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 给文件设置文档打开密码
workbook.Protect("12345Open")

# 保存结果文件
workbook.SaveToFile("文档打开密码.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

Python 使用文档修改密码保护 Excel 文件

文档修改密码用于限制未经授权的人修改或编辑文档。设置了修改密码后,任何人都需要输入正确的密码才能成功修改该Excel文件内容。

要给Excel文件设置文档修改密码,可以使用Workbook.SetWriteProtectionPassword()方法。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.SetWriteProtectionPassword()方法给该Excel文件设置文档修改密码。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 给文件设置文档修改密码
workbook.SetWriteProtectionPassword("12345Modify")

# 保存结果文件
workbook.SaveToFile("文档修改密码.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

需要注意的是,文档打开密码和修改密码可以单独设置,也可以同时设置。当同时设置了这两种密码时,用户不仅需要输入正确的打开密码才能打开文件,还需要输入正确的修改密码才能编辑文件内容。

Python 将 Excel 文件标记为最终版本

当Excel文件被标记为最终版本后,其他用户在打开文件时会看到"此文件已被标记为最终版本"的提示,从而知道不应再对其进行编辑。这种方式可以有效防止Excel文件被意外修改。

要将Excel文件标记为最终版本,可以使用Workbook.CustomDocumentProperties.Add("_MarkAsFinal", True)方法。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.CustomDocumentProperties.Add("_MarkAsFinal", True)方法将该Excel文件标记为最终版本。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 将文档标记为最终版本
workbook.CustomDocumentProperties.Add("_MarkAsFinal", True)

# 保存结果文件
workbook.SaveToFile("最终版本.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

Python 保护 Excel 工作表

除了保护整个Excel文件以外,Excel还支持对单个工作表进行保护,从而限制用户对特定工作表的编辑操作。

要保护特定Excel工作表,可以使用Worksheet.Protect()方法。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.Worksheets[index]属性获取特定工作表。
  • 使用Worksheet.Protect()方法保护该工作表。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 用密码保护工作表,并指定保护类型
sheet.Protect("Sheet111", SheetProtectionType.none)

# 保存结果文件
workbook.SaveToFile("保护工作表.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

Python 在保护 Excel 工作表的同时允许编辑某些单元格

在保护 Excel 工作表时,你可以设置可编辑区域,以允许用户编辑被保护工作表中的某些特定单元格。

要设置工作表的可编辑区域,可以使用Worksheet.AddAllowEditRange()方法。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.Worksheets[index]属性获取特定工作表。
  • 使用Worksheet.AddAllowEditRange()方法指定保护工作表后可编辑的单元格区域。
  • 使用Worksheet.Protect()方法保护该工作表。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 指定可编辑的单元格区域
sheet.AddAllowEditRange("Range1", sheet.Range["B2:E11"])

# 用密码保护工作表
sheet.Protect("Sheet111", SheetProtectionType.none)

# 保存结果文件
workbook.SaveToFile("可编辑区域.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

Python 锁定 Excel 工作表中的特定单元格

如果 Excel 工作表中一些关键单元格包含重要的公式或数据,你可以对这些单元格进行锁定保护。这样可以防止普通用户对这些关键单元格进行编辑,同时仍然让他们可以对其他单元格进行操作。

要锁定特定单元格,可以使用Worksheet.Range[].Style.Locked属性。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.Worksheets[index]属性获取特定工作表。
  • 使用Worksheet.Cells属性获取工作表的单元格集合。
  • 循环遍历单元格,并取消所有单元格的锁定状态 (Excel中所有单元格的锁定状态默认是选中的)。
  • 使用Worksheet.Range[].Style.Locked属性锁定特定单元格或单元格区域。
  • 使用Worksheet.Protect()方法保护该工作表。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 获取工作表的单元格集合
cellsCollection = sheet.Cells

# 循环遍历单元格,并取消所有单元格的锁定状态 (在Excel中,所有单元格的锁定状态默认都是选中的)
for cell in cellsCollection:
    cell.Style.Locked = False

# 锁定特定的单元格区域
sheet.Range["A1:E1"].Style.Locked = True

# 用密码保护工作表
sheet.Protect("Sheet111", SheetProtectionType.none)

# 保存结果文件
workbook.SaveToFile("锁定单元格.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

Python 锁定 Excel 工作表中的特定行或列

除了锁定特定的单元格或区域外,你还可以锁定整行或整列。

要锁定特定的行或列,可以使用Worksheet.Rows[index].Style.LockedWorksheet.Columns[index].Style.Locked属性。具体步骤如下:

  • 创建Workbook类的实例。
  • 使用Workbook.LoadFromFile()方法加载Excel文件。
  • 使用Workbook.Worksheets[index]属性获取特定工作表。
  • 使用Worksheet.Cells属性获取工作表的单元格集合。
  • 循环遍历单元格,并取消所有单元格的锁定状态 (Excel中所有单元格的锁定状态默认是选中的)。
  • 使用Worksheet.Rows[index].Style.LockedWorksheet.Columns[index].Style.Locked属性锁定特定行或列。
  • 使用Worksheet.Protect()方法保护该工作表。
  • 使用Workbook.SaveToFile()方法保存结果文件。

完整代码:

from spire.xls import *
from spire.xls.common import *

# 创建一个 Workbook 对象
workbook = Workbook()
# 加载一个 Excel 文件
workbook.LoadFromFile("测试.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 获取工作表的单元格集合
cellsCollection = sheet.Cells

# 循环遍历单元格,并取消所有单元格的锁定状态 (在Excel中,所有单元格的锁定状态默认都是选中的)
for cell in cellsCollection:
    cell.Style.Locked = False

# 锁定第一行和第一列
sheet.Rows[0].Style.Locked = True
sheet.Columns[0].Style.Locked = True

# 用密码保护工作表
sheet.Protect("Sheet111", SheetProtectionType.none)

# 保存结果文件
workbook.SaveToFile("锁定行列.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

以上就是使用Python保护或加密Excel文件的7种不同的场景。希望对你有帮助。

本文完结-

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1818653.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Elasticsearch:智能 RAG,获取周围分块

作者:来自 Elastic Sunile Manjee 在检索增强生成 (RAG) 领域,一个持续存在的挑战是找到输入大型语言模型 (LLM) 的最佳数据量。数据太少会导致响应不足或不准确,而数据太多会导致答案模糊。这种微妙的平衡启发我开发了一个专注于智能分块和利…

ssm的疫情物资管理系统

ssm的疫情物资管理系统 功能:前端页面展示 用户端:主页展示,新闻展示,疫情物资,在线留言,全国疫情,健康打卡,注册,登录 后端管理:登录,账号管理…

2024怎么选择开放式耳机?五款高评分机型推荐!

还记得我最早接触到不入耳的耳机是在前几年,上课需要一副耳机,我又受不住长时间的戴耳机,那时候如利刃一款蛮贵的开放式耳机,时过境迁现在已随着人们的需求发展至到至今的真无线的开放式蓝牙耳机,我也在这几年之内入手…

Postman下发流表至Opendaylight

目录 任务目的 任务内容 实验原理 实验环境 实验过程 1、打开ODL控制器 2、网页端打开ODL控制页面 3、创建拓扑 4、Postman中查看交换机的信息 5、L2层流表下发 6、L3层流表下发 7、L4层流表下发 任务目的 1、掌握OpenFlow流表相关知识,理解SDN网络中L…

【AI绘画】Stable Diffusion 3开源

Open Release of Stable Diffusion 3 Medium 主要内容 Stable Diffusion 3是Stability AI目前为止最先进的文本转图像开放源代码算法。 这款模型的小巧设计使其完美适合用于消费级PC和笔记本电脑,以及企业级图形处理单元上运行。它已经满足了标准化的文字转图像模…

红黑树(C++)

文章目录 写在前面1. 红黑树的概念及性质1. 1 红黑树的概念1. 2 红黑树的性质 2. 红黑树节点的定义3. 红黑树的插入3.1 按照二叉搜索的树规则插入新节点3.2 检测新节点插入后,红黑树的性质是否造到破坏 4.红黑树的删除5.红黑树的验证6.源码 写在前面 在上篇文章中&…

移动UI:登录页如此哇塞,不发出就有点锦衣夜行啦。

移动UI登录页是移动应用中非常重要的一环。一个出色的登录页可以给用户留下深刻的印象,提供良好的用户体验,并确保用户的账号安全 在设计登录页时,可以考虑以下几个方面: 简洁明了的界面:登录页应该简洁明了&#xf…

关于一元方程求根中牛顿迭代法的分析

文末含有程序源代码以及可执行exe文件,文中部分内容参考网上博客以及GPT协助,希望能对你有所帮助~ 一、理论知识简述 牛顿迭代法(Newton’s Method),也称为牛顿-拉弗森方法(Newton-Raphson Method&#xf…

罗森伯格1800M 2000M 2400M 900M无源互调分析仪

在无线通信领域,频段是宝贵的资源,不同的通信系统通常会采用不同的频段以满足其传输需求。随着技术的发展,越来越多的通信系统被部署在各种频段上。为了准确、高效地测试和调试这些 信系统,各种测试设备也应运而生。源互调分析仪便…

rizhuti1.9-最新版-推荐文章缩略图

下载地址:rizhuti1.9-最新版-推荐文章缩略图 商城功能后台可以一键开启关闭,关闭后就是一个布局灵活,界面优美,速度超快的wordpress博客主题

2024新版AI创作系统pro搭建,支持文生漫画视频ai对话问答/ai音乐创作/ai测评/ai换脸/ai写真

一、系统介绍 一款结合了多种功能应用,是当前市场最热门的AI工具综合体 AI动漫生成 AI音乐创作 AI写真 AI换脸 AI绘画 AI趣测 六大AI功能 AI创作小程序是一种利用人工智能技术为用户提供服务,并通过某种方式实现的小程序。这种小程序可以应用于多…

微服务 | Springboot整合Dubbo+Nacos实现RPC调用

官网:Apache Dubbo 随着互联网技术的飞速发展,越来越多的企业和开发者开始关注微服务架构。微服务架构可以将一个大型的应用拆分成多个独立、可扩展、可维护的小型服务,每个服务负责实现应用的一部分功能。这种架构方式可以提高开发效率&…

RK3568技术笔记 Ubuntu 安装VMware Tools

安装 VMware Tools 后可以直接使用复制粘贴功能拷贝 Ubuntu 系统和 windows 主机内的文件,非常方便。 开启虚拟机,必须要进入ubuntu系统后才能进行下面的步骤。 单击 VMware 软件中的标签“虚拟机”,在下拉的菜单中单击“安装VMware Tools &…

x64-linux下在vscode使用vcpkg

1.使用vscode远程连接上对应的linux ,或者直接在图形化界面上使用。 2.安装vcpkg 插件,然后打开插件设置。 注意:defalut和host的主机一定和你自己的主机一致,且必须符合vcpkg三元组格式,其中你可以选择工作台的设置&a…

R语言ggHoriPlot包绘制地平线图

数据和代码获取:请查看主页个人信息!!! 关键词“地平线图” 1. 数据读取与处理 首先,从TSV文件中读取数据,并进行数据清洗和处理。 rm(listls()) pacman::p_load(tidyverse,ggalt,ggHoriPlot,hrbrthemes…

ACM MM2024 Rebuttal Latex模板如何去掉标题

声明 Latex初学者,非官方指定做法,仅供大家参考 问题 ACM MM 2024会议,官方给定的Rebuttal latex模板,title占据了两行,但又限制Rebuttal只能有一页,所以在微信群里,大家希望能将这个title删…

springboot 整合redis问题,缓存击穿,穿透,雪崩,分布式锁

boot整合redis 压力测试出现失败 解决方案 排除lettuce 使用jedis <!-- 引入redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><exclusions><exclus…

快来!AI绘画Stable Diffusion 3终于开源了,更强的文字渲染和理解力,12G显卡可跑!

大家好&#xff0c;我是设计师阿威 Stable Diffusion 3终于开源了&#xff0c;2B参数的Stable Diffusion 3 Medium模型已经可以在HuggingFace上下载了&#xff01;如无法科学上网的小伙伴我也准备好了网盘资料&#xff0c;请看文末扫描获取哦&#xff01; Stable Diffusion 3 …

力扣每日一题-419

题目 给你一个大小为 m x n 的矩阵 board 表示甲板&#xff0c;其中&#xff0c;每个单元格可以是一艘战舰 X 或者是一个空位 . &#xff0c;返回在甲板 board 上放置的 战舰 的数量。 战舰 只能水平或者垂直放置在 board 上。换句话说&#xff0c;战舰只能按 1 x k&#xff…

C++中stack和queue

前言 在 C 中&#xff0c;stack&#xff08;栈&#xff09;和 queue&#xff08;队列&#xff09;是两种常用的容器适配器&#xff0c;分别用于管理数据的后进先出&#xff08;LIFO&#xff09;和先进先出&#xff08;FIFO&#xff09;访问模式。本文将详细介绍这两种数据结构的…