读取 Excel 文件

以下是一个示例,展示如何使用 OpenPyXL 读取 Excel 文件并打印其内容:

复制代码
import openpyxl

# 打开一个已有的工作簿
workbook = openpyxl.load_workbook("sample.xlsx")

# 获取活动的工作表或指定工作表
sheet = workbook.active  # 或者使用 sheet = workbook["SheetName"]

# 读取工作表中的数据
for row in sheet.iter_rows(values_only=True):
    print(row)

示例代码解释

  1. 打开一个已有的工作簿:

    • workbook = openpyxl.load_workbook("sample.xlsx") 打开一个名为 sample.xlsx 的 Excel 文件。
  2. 获取活动的工作表或指定工作表:

    • sheet = workbook.active 获取活动的工作表(默认是第一个工作表)。
    • 或者使用 sheet = workbook["SheetName"] 获取指定名称的工作表。
  3. 读取工作表中的数据:

    • for row in sheet.iter_rows(values_only=True): 迭代工作表中的每一行,并设置 values_only=True 以只返回单元格的值,而不包括单元格对象。
    • print(row) 打印每一行的数据。

进一步的操作

除了简单地读取和打印数据,你还可以进行更多复杂的操作,例如读取特定单元格的数据、处理多个工作表等。以下是一些示例:

读取特定单元格的数据
复制代码
import openpyxl

# 打开工作簿
workbook = openpyxl.load_workbook("sample.xlsx")

# 获取指定工作表
sheet = workbook.active

# 读取特定单元格的数据
cell_value = sheet['A1'].value
print(f"Value in A1: {cell_value}")
处理多个工作表
复制代码
import openpyxl

# 打开工作簿
workbook = openpyxl.load_workbook("sample.xlsx")

# 获取所有工作表的名称
sheet_names = workbook.sheetnames
print("Sheet names:", sheet_names)

# 读取每个工作表中的数据
for sheet_name in sheet_names:
    sheet = workbook[sheet_name]
    print(f"Data in {sheet_name}:")
    for row in sheet.iter_rows(values_only=True):
        print(row)

通过这些步骤,你可以使用 OpenPyXL 库轻松地读取和处理 Excel 文件中的数据。

相关推荐
三十..3 分钟前
Redis 核心原理与高可用架构实践
运维·数据库·redis
Linlingu15 分钟前
openClaw不能操作我的电脑提示没有权限如何解决?
人工智能·windows·办公自动化·数字员工·小龙虾
努力努力再努力wz37 分钟前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
会Tk矩阵群控的小木1 小时前
基于Python的iMessage短信群发与社媒多账号统一管理系统实现
开发语言·windows·python·新媒体运营·开源软件·个人开发
Jurio.1 小时前
开源 Codex Sticky:在终端 Codex CLI 长对话中始终固定底部输入框
linux·rust·github·开源软件·codex·codex cli
无足鸟ICT1 小时前
【RHCA+】撤销和恢复撤销快捷键
linux
质造者1 小时前
LangChain + Ollama + Tavily 实现旅游问答系统
linux·人工智能·python·langchain·rag
starvapour2 小时前
Ubuntu部署gitlab频繁出现502的问题
linux·ubuntu·gitlab
jinglong.zha2 小时前
LScript-从零基础到商业变现的AI自动化学习平台
运维·学习·自动化
Adorable老犀牛2 小时前
Telegraf:InfluxData 出品的指标采集代理
运维·telegraf