用Python设置、更新和获取Excel单元格的值

Excel工作簿作为一款广泛使用的数据管理工具,与Python相结合,可以使得自动化处理大量数据成为可能。通过Python来设置、更新以及读取Excel单元格的值,不仅可以极大地提高工作效率,减少重复劳动,还能增强数据处理流程的灵活性与可扩展性,进而创造更多价值。这种方法的应用场景从财务报表自动化到数据分析报告的生成,在各种工作领域都可以带来很大的效率提升。本文将演示如何使用Python设置、更新以及获取Excel文件中单元格的值

文章目录

    • 使用Python设置Excel单元格的值
    • 使用Python更新Excel单元格的值
    • 使用Python获取Excel单元格的值

本文所使用的方法需要用到Spire.XLS for Python,PyPI:pip install spire.xls

使用Python设置Excel单元格的值

我们可以使用库中的Worksheet.Range.get_Item()方法来获取Excel工作表中的指定单元格为CellRange对象,如Range.get_Item(2, 1)Range.get_Item("A2")(第二行第一列)。然后,我们可以CellRange.Value属性来设置单元格的值,或使用该类下的其他属性来设置单元格文本、数字、布尔值以及其他类型的值。同时,我们还可以使用CellRange类下的格式设置相关属性来设置单元格的格式等。以下是操作步骤示例:

  1. 导入所需模块:WorkbookFileFormatDateTimeHorizontalAlignType
  2. 创建Workbook对象。
  3. 使用Workbook.Worksheets.Clear()方法清除默认工作表,并使用Workbook.Worksheets.Add(sheetName: str)方法新建一个工作表。
  4. 使用Worksheet.Range.get_Item()方法获取指定单元格为CellRange对象。
  5. 使用CellRange对象下的属性设置单元格值,如TextValueDataTimeValueFormulaNumberValue属性。
  6. 设置单元格格式。
  7. 使用Workbook.SaveToFile()方法保存工作簿。
  8. 释放资源。

代码示例

from spire.xls import Workbook, FileFormat, DateTime, HorizontalAlignType
import datetime# 创建Workbook的实例从而创建一个Excel工作簿
workbook = Workbook()# 清除默认工作表并添加一个新工作表
workbook.Worksheets.Clear()
sheet = workbook.Worksheets.Add("Sheet1")# 获取一个单元格并设置文本
cell = sheet.Range.get_Item(2, 2)
cell.Text = "文本示例"# 获取一个单元格并设置普通值
cell1 = sheet.Range.get_Item(3, 2)
cell1.Value = "$123456"# 获取一个单元格并设置日期值
cell2 = sheet.Range.get_Item(4, 2)
cell2.DateTimeValue = DateTime.get_Now()# 获取一个单元格并设置布尔值
cell3 = sheet.Range.get_Item(5, 2)
cell3.BooleanValue = True# 获取一个单元格并设置公式
cell4 = sheet.Range.get_Item(6, 2)
cell4.Formula = "=SUM(B7)"# 获取一个单元格并设置数字值及数字格式
cell5 = sheet.Range.get_Item(7, 2)
cell5.NumberValue = 123456
cell5.NumberFormat = "#,##0.00"# 获取一个单元格并设置公式数组
cell6 = sheet.Range.get_Item(8, 2)
cell6.HtmlString = "<p><span style='color: blue; font-size: 18px;'>蓝色字体18像素大小</span></p>"# 设置格式
cellRange = sheet.Range.get_Item(2, 2, 7, 2)
cellRange.Style.Font.FontName = "Arial"
cellRange.Style.Font.Size = 14
cellRange.Style.HorizontalAlignment = HorizontalAlignType.Left# 自动调整列宽
sheet.AutoFitColumn(2)# 保存文件
workbook.SaveToFile("output/SetExcelCellValue.xlsx", FileFormat.Version2016)
workbook.Dispose()

结果
Python设置Excel单元格的值

使用Python更新Excel单元格的值

在更新Excel单元格的值时,我们可以直接获取相应的单元格并使用上述设置值的方法重新设置值,从而实现对单元格的值的更新。以下是操作步骤示例:

  1. 导入所需模块:Workbook
  2. 创建Workbook对象。
  3. 使用Workbook.LoadFromFile()方法载入Excel文件。
  4. 使用Workbook.Worksheets.get_Item()方法获取工作表。
  5. 使用Worksheet.Range.get_Item()方法获取单元格。
  6. 使用CellRange类下的方法重新设置单元格的值。
  7. 使用Workbook.SaveToFile()方法保存工作簿。
  8. 释放资源。

代码示例

from spire.xls import Workbook# 创建一个Workbook实例
workbook = Workbook()# 载入Excel文件
workbook.LoadFromFile("output/SetExcelCellValue.xlsx")# 获取一个工作表
sheet = workbook.Worksheets.get_Item(0)# 获取一个单元格
cell = sheet.Range.get_Item(2, 2)# 更改单元格值
cell.NumberValue = 45150
cell.NumberFormat = "[Green]#,##0;[RED]-#,##0"# 保存工作簿
workbook.SaveToFile("output/UpdateExcelCellValue.xlsx")
workbook.Dispose()

结果
Python更新Excel单元格的值

使用Python获取Excel单元格的值

CellRange.Value属性可以直接读取到单元格的。以下是读取Excel单元格的值的操作步骤示例:

  1. 导入所需模块:Workbook
  2. 创建Workbook对象。
  3. 使用Workbook.LoadFromFile()方法载入Excel文件。
  4. 使用Workbook.Worksheets.get_Item()方法获取工作表。
  5. 遍历指定范围内的单元格,使用CellRange.Value属性获取单元格的值。
  6. 输出结果。
  7. 释放资源。

代码示例

from spire.xls import Workbook# 创建一个Workbook实例
workbook = Workbook()# 载入Excel文件
workbook.LoadFromFile("output/SetExcelCellValue.xlsx")# 获取一个工作表
sheet = workbook.Worksheets.get_Item(0)# 遍历第2列第2行到第8行的单元格
for i in range(2, 8):# 获取单元格cell = sheet.Range.get_Item(i, 2)# 获取单元格的值value = cell.Value# 输出值print(value)
workbook.Dispose()

结果
Python获取Excel单元格的值

本文演示了如何使用Python设置、更新及获取Excel单元格的值。

申请免费License

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

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

相关文章

利用ChatGPT完成2024年MathorCup大数据挑战赛-赛道A初赛:台风预测与分析

利用ChatGPT完成2024年MathorCup大数据挑战赛-赛道A初赛&#xff1a;台风预测与分析 引言 在2024年MathorCup大数据挑战赛中&#xff0c;赛道A聚焦于气象数据分析&#xff0c;特别是台风的生成、路径预测、和降水风速特性等内容。本次比赛的任务主要是建立一个分类评价模型&…

Logback 常用配置详解

1. 配置文件解析 Logback 是 Spring Boot 默认使用的日志框架&#xff0c;Logback 配置主要包含 8 大元素 1.1 configuration Logback 配置文件的根元素&#xff0c;它包含所有的配置信息 1.2 appender 定义一个 Appender&#xff0c;即日志输出的目的地&#xff0c;如控制…

造纸行业湿法粉碎机、高速破碎机、粉碎磨粉机

细胞磨在造纸行业的应用主要体现在以下几个方面&#xff1a; 1.原料处理 细碎与研磨&#xff1a;造纸行业的原料&#xff0c;如木材、竹材等&#xff0c;需要经过细碎和研磨处理以获取适合造纸的纤维。细胞磨能够高效地实现这一过程&#xff0c;将原料细化至所需的粒度&#…

JAVA基础:jdbc (学习笔记)

基础操作 任何一种jdbc操作&#xff0c;都是由7步完成的 手动加载数据库驱动类{反射}获得连接对象写sql语句获得执行对象执行sql语句&#xff0c;同时获得结果处理结果关闭资源 功能一&#xff1a;添加表里的数据 public static void main4(String[] args) throws ClassNotF…

RabbitMQ最全教程-Part1(基础使用)

一、消息队列基本概念 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用解耦&#xff0c;异步消息&#xff0c;流量削锋等问题&#xff0c;实现高性能&#xff0c;高可用&#xff0c;可伸缩和最终一致性架构 1、消息队列的特点 可靠性 消息持久化&#xff…

英伟达 GPU 架构:演进与模型推理速度的深度关联

英伟达的 GPU 架构演进之路充满了创新与突破。 ©作者|Zane 来源|神州问学 一、 英伟达GPU的架构演进之路 1999 年&#xff0c;英伟达发布 Geforce256 图形处理芯片&#xff0c;首次提出 GPU 概念。早期的架构如 G80 或 GeForce 8800 GTX&#xff0c;包含 8 个 TPC&#…

Yolo V4详解

Yolo V4&#xff08;You Only Look Once version 4&#xff09;是一种先进的目标检测系统&#xff0c;于2020年推出。作为Yolo系列算法的最新版本&#xff0c;Yolo V4继承了其前代版本的优点&#xff0c;并在此基础上进行了多项改进&#xff0c;使得其性能得到了显著提升。本文…

实体类中为什么要实现serializable接口

最近见到好多项目中写的代码&#xff0c;在实体类中实现了Serializable接口。说实话&#xff1a;这个在以前学习的时候&#xff0c;貌似学过&#xff0c;但是一直没有用过&#xff0c;所以看着一脸懵逼&#xff0c;但是别人总不可能随便写的吧.....所以就去查了一下这个接口。 …

D55【python 接口自动化学习】- python基础之模块与标准库

day55 练习&#xff1a;实现求导 学习日期&#xff1a;20241101 学习目标&#xff1a;模块与标准库 -- 70 小试牛刀&#xff1a;如何使用Python为函数求导&#xff1f; 学习笔记&#xff1a; 需求分析 使用第三方模块实现函数求导 编写程序并测试 # 求导 from sympy import…

推荐一款功能强大的AI实时变声器:FliFlik Voice Changer

FliFlik VoiCE Changer是一款专注于声音变换与音频处理的创新软件&#xff0c;旨在满足从日常娱乐、游戏直播到播客制作、专业音频编辑的多种应用场景需求。无论是想在游戏中变换声音逗乐队友&#xff0c;还是在播客中塑造个性化的音效&#xff0c;这款软件都能提供灵活而强大的…

Spring Boot技术栈:打造大学城水电管理系统

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…

2024 IC行业还能不能入了?

打个有趣的比方&#xff0c;18年以前入行IC的&#xff0c;就业前就知道或者就业后才知道&#xff0c;是去吃席只不过是“农村酒席”&#xff0c;但不至于吃坏肚子。对于这种阵仗&#xff0c;不是每个人都愿意去的&#xff0c;即便是在西电这样的院校&#xff0c;当年也有一些同…

基于双向长短期记忆网络(BiLSTM)的时间序列数据预测,15个输入1个输出,可以更改数据集,MATLAB代码

1. 数据收集与预处理 数据清洗&#xff1a;处理缺失值、异常值等。特征工程&#xff1a;提取有助于预测的特征。数据标准化&#xff1a;将时间序列数据标准化&#xff0c;使其具有零均值和单位方差&#xff0c;有助于模型训练。滑动窗口划分&#xff1a;将时间序列数据划分为多…

基于Python可视化的热门微博数据分析系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于pythondjangovueMySQL的热…

推荐一款非常好用的3d设计软件:LuBan 3D

LuBan 3D是一款非常好用的3d设计软件&#xff0c;这款软件提供独特的3D的模型以及设计的理念&#xff0c;还可以自动为用户处理像三角形OBJ&#xff0c;PLY等网格模型。 基本简介 LuBan 3D是一款非常小巧但是功能十分强大的生成式设计软件。这款软件对于设计师和制作们来说非常…

Comfyui-Flux写实人像摄影风格探索

在一些小伙伴的建议下&#xff0c;我最近开始着手整理ComfyUI的相关内容。其实之前就一直在关注这个工具&#xff0c;但由于工作繁忙&#xff0c;一直没能抽出时间去总结。 与SD webui不同的是,comfyui有着极高的自由度和灵活性&#xff0c;支持高度的定制化和工作流复用&#…

qt QPicture详解

1、概述 QPicture类是Qt框架中的一个重要图形类&#xff0c;它主要用于记录和回放QPainter的绘图指令。这个类能够跨平台、无分辨率依赖地绘制图形&#xff0c;非常适合用于实现打印预览和图像操作等场景。QPicture可以将绘图操作序列化为一种独立于平台的格式&#xff0c;保存…

Axure使用动态面板制作新闻栏目高级交互

亲爱的小伙伴&#xff0c;在您浏览之前&#xff0c;烦请关注一下&#xff0c;在此深表感谢&#xff01; 课程主题&#xff1a;使用动态面板制作新闻栏目 主要内容&#xff1a;动态面板State切换、控制&#xff1b;动态面板滚动设置&#xff1b;设置选中 应用场景&#xff1a…

Jupyter lab 打开时默认使用 Notebook 而不是浏览器

Jupyter lab 打开时默认使用 Notebook 而不是浏览器 正文 正文 今天遇到了一个特别有意思的事情&#xff0c;这里我们以 Windows \textrm{Windows} Windows 系统举例。 我们知道通常我们需要使用如下代码在 Terminal \textrm{Terminal} Terminal 中打开 Jupyter lab \textr…

h5小游戏5--杀死国王(附源码)

源代码如下 1.游戏基本操作 用空格键攻击&#xff0c;kill the king。 css样式源码 charset "UTF-8";font-face {font-family: "AddLGBitmap09";src: url("https://assets.codepen.io/217233/AddLGBitmap09.woff2") format("woff2"…