用Python代码锁定Excel单元格以及行和列

Excel能够帮助用户高效地组织数据,还支持复杂的公式计算和数据分析。而随着团队协作的日益频繁,保护数据的准确性和完整性变得尤为重要。在Excel表格中,我们可以通过锁定特定的单元格或区域,防止对单元格内容进行随意修改,确保关键数据、公式或格式不被误改,从而维护表格的一致与可靠。本文将介绍如何使用Python代码来实现对Excel单元格的锁定,实现批量操作以及自动化。

文章目录

    • 用Python锁定Excel工作表中的指定单元格
    • 用Python锁定Excel工作表中的指定列

本文所使用的方法基于Spire.XLS for Python,PyPI:pip install Spire.XLS

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

我们可以通过将 Worksheet.Range[].Style.Locked 属性设置 True 来实现对指定单元格范围进行锁定的操作。
注意:Excel工作表中的所有单元在默认情况下都是锁定状态,但单元格锁定在Excel文件本身没有设置密码时不会生效。所以我们在锁定指定单元格时,需要先解锁所有单元格,然后再锁定指定单元格并为文件设置密码。
以下是操作步骤:
导入所需模块。

  1. 创建 Workbook 实例,并使用 Workbook.LoadFromFile() 方法加载Excel文件。
  2. 使用 Workbook.Worksheets.get_Item() 方法获取第一个工作表。
  3. 通过将 Worksheet.Range.Style.Locked 属性设置为 False,解除对工作表所用范围内所有单元格的锁定。
  4. 将指定单元格 Worksheet.Range[].Style.Locked 属性设置为 “True ”从而进行锁定。
  5. 使用 XlsWorksheetBase.Protect() 方法保护工作表。
  6. 使用 Workbook.SaveToFile() 方法保存结果文件。

代码示例

from spire.xls import *
from spire.xls.common import *# 创建一个Workbook实例并加载示例文件
workbook = Workbook()
workbook.LoadFromFile("示例.xlsx")# 获取第一个工作表
sheet = workbook.Worksheets.get_Item(0)# 解锁工作表中使用范围内的所有单元格
sheet.Range.Style.Locked = False# 锁定工作表中的特定单元格
sheet.Range["A2"].Style.Locked = True# 锁定工作表中的特定单元格范围
sheet.Range["F3:H4"].Style.Locked = True# 使用密码保护工作表
sheet.Protect("123456", SheetProtectionType.All)# 保存结果文件
workbook.SaveToFile("output/锁定Excel单元格.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

结果
Python锁定Excel单元格

用Python锁定Excel工作表中的指定列

如果需要对指定列或行进行锁定,也可以使用相似的方法,将 Worksheet.Columns[].Style.LockedWorksheet.Rows[].Style.Locked 属性设置为 True
以下是操作步骤:

  1. 创建 Workbook 实例,并使用 Workbook.LoadFromFile() 方法加载Excel文件。
  2. 使用 Workbook.Worksheets.get_Item() 方法获取第一个工作表。
  3. 通过将 Worksheet.Range.Style.Locked 属性设置为 False,解除对工作表所用范围内所有单元格的锁定。
  4. 将指定列或行 Worksheet.Columns[].Style.LockedWorksheet.Rows[].Style.Locked 属性设置为 “True ”从而进行锁定。
  5. 使用 XlsWorksheetBase.Protect() 方法保护工作表。
  6. 使用 Workbook.SaveToFile() 方法保存结果文件。

代码示例

from spire.xls import *
from spire.xls.common import *# 创建一个Workbook实例并加载示例文件
workbook = Workbook()
workbook.LoadFromFile("示例.xlsx")# 获取第一个工作表
sheet = workbook.Worksheets.get_Item(0)# 解锁工作表中使用范围内的所有单元格
sheet.Range.Style.Locked = False# 锁定工作表中的第一列
sheet.Columns[0].Style.Locked = True# 锁定工作表中的第二行
sheet.Rows[1].Style.Locked = True# 使用密码保护工作表
sheet.Protect("123456", SheetProtectionType.All)# 保存结果文件
workbook.SaveToFile("output/锁定Excel行和列.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

本文介绍了如何使用Python代码实现锁定Excel工作表中的指定单元格,包括锁定单元格范围、锁定行以及锁定列。

更多Excel文件操作技巧请前往Spire.XLS for Python教程查看。

申请免费License

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++面向对象程序设计 - 命名空间

命名空间是ANSI C引入的可以由用户命名的作用域,用来处理程序中常见的同名冲突。 在C语言中定义了三个层次的作用域,即文件(编译单元)、函数和复合语句。C又引入了类作用域,类是出现在文件内的。在不同的作用域中可以定…

14.shell awk数组

awk数组 awk数组awk数组示例Nginx日志分析 awk数组 1.什么是awk数组 数组其实也算是变量,传统的变量只能存储一个值,但数组可以存储多个值 2.awk数组应用场景 通常用来统计、比如:统计网站访问TOP10、网站url访问TOP10等等 3.awk数组统计技巧 1.在awk中,使用数组时,不仅可以…

ceisum只聚合效果展示

忙于开发三维引擎的扩展功能,实在时间太少了,仓促截几张图,看一下聚合效果。 1.聚合又文字标签 四种效果:如下 2.聚合无文字标签

Docker(一)-认识Docker

1.docker理念 Docker是基于Go语言实现的云开源项目。 Docker的主要目标是“Build,Ship and Run Any App,Anywhere”,也就是通过对应用组件的封装,分发,部署,运行等生命周期的管理,使用户的应用及其运行环境能够做到”…

jenkins使用注意问题

1.在编写流水线时并不知道当前处在哪个目录,导致名使用不当,以及文件位置不清楚 流水线任务默认路径是,test4_mvn为jenkins任务名 [Pipeline] sh (hide)pwd /var/jenkins_home/workspace/test4_mvn maven任务也是,看来是一样的…

CV每日论文--2024.6.14

1、ICE-G: Image Conditional Editing of 3D Gaussian Splats 中文标题:ICE-G:3D 高斯斑点的图像条件编辑 简介:近年来,出现了许多技术来创建高质量的3D资产和场景。然而,当涉及到这些3D对象的编辑时,现有方法要么速度慢、要么牺牲质量,要么…

数组(C语言)(详细过程!!!)

目录 数组的概念 一维数组 sizeof计算数组元素个数 二维数组 C99中的变⻓数组 数组的概念 数组是⼀组相同类型元素的集合。 数组分为⼀维数组和多维数组,多维数组⼀般比较多见的是二维数组。 从这个概念中我们就可以发现2个有价值的信息:(1)数…

flask_sqlalchemy时间缓存导致datetime.now()时间不变问题

问题是这样的,项目在本地没什么问题,但是部署到服务器过一阵子发现,这个时间会在某一刻定死不变。 重启uwsgi后,发现第一条数据更新到了目前最新时间,过了一会儿再次发送也变了时间,但是再过几分钟再发就会…

软件测试--Mysql快速入门

文章目录 软件测试-mysql快速入门sql主要划分mysql常用的数据类型sql基本操作常用字段的约束:连接查询mysql内置函数存储过程视图事务索引 软件测试-mysql快速入门 sql主要划分 sql语言主要分为: DQL:数据查询语言,用于对数据进…

基于Verilog表达的FSM状态机

基于Verilog表达的FSM状态机 1 FSM1.1 Intro1.2 Why FSM?1.3 How to do 在这里聚焦基于Verilog的三段式状态机编程; 1 FSM 1.1 Intro 状态机是一种代码实现功能的范式;一切皆可状态机; 状态机编程四要素:– 1.状态State&#…

通用大模型与垂直大模型:双轨并进的人工智能未来

在人工智能(AI)的浩瀚宇宙中,大模型以其强大的学习能力和广泛的适用性,正逐步成为推动技术进步和产业革新的核心动力。在这股浪潮中,通用大模型与垂直大模型如同两颗璀璨的星辰,各自散发着独特的光芒,共同照亮了AI发展…

STL入门指南:从容器到算法的完美结合

目录 ​编辑 一、什么是STL 二、STL的版本 三、STL的六大组件 1. 容器(Containers): 2. 算法(Algorithms): 3. 迭代器(Iterators): 4. 仿函数(Functo…

中国算力基础设施“第一阵营”变局?

2024年6月IDC最新数据显示,2024年第一季度,联想服务器跃升至中国市场份额第三位。中国算力基础设施“第一阵营”正生变局。 在去年服务器本地化品牌联想问天发布之后,联想就发出了向国内服务器市场冲锋的信号。如今仅一年,就进入…

工业4.0下的PLC进化论:ARMxy计算机如何重塑自动化

智能物流系统的高效与精准成为企业竞争力的关键。在这个背景下,传统的PLC系统因其固有的局限性,如扩展性差、系统封闭等,开始显得力不从心。ARMxy工业计算机作为新一代的PLC替代方案,凭借其低功耗、高性能以及高度的灵活性&#x…

Android Studio历史版本

android studio的历史版本

自然语言处理领域的重大挑战:解码器 Transformer 的局限性

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

本地Zabbix开源监控系统安装内网穿透实现远程访问详细教程

文章目录 前言1. Linux 局域网访问Zabbix2. Linux 安装cpolar3. 配置Zabbix公网访问地址4. 公网远程访问Zabbix5. 固定Zabbix公网地址 💡推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【…

【机器学习】机器学习赋能医疗健康:从诊断到治疗的智能化革命

📝个人主页🌹:Eternity._ 🌹🌹期待您的关注 🌹🌹 ❀目录 📒1. 引言📙2. 机器学习在疾病诊断中的应用🧩医学影像分析:从X光到3D成像带代码&#x1…

我的考研经历

当我写下这篇文章时,我已经从考研 的失败中走出来了,考研的整个过程都写在博客日志里面了,在整理并阅读考研的日志时,想写下一篇总结,也算是为了更好的吸取教训。 前期日志模板:时间安排的还算紧凑&#x…

vivado HW_VIO

描述 虚拟输入/输出(VIO)调试核心hw_VIO可以监视和驱动内部 在编程的XilinxFPGA上实时显示信号。在没有物理访问的情况下 目标硬件,可以使用此调试功能来驱动和监视 存在于物理设备上。 VIO核心具有硬件探测器hw_probe对象,用于监…