0

0

python中如何操作Excel文件_Python使用openpyxl/pandas操作Excel

尼克

尼克

发布时间:2025-09-11 18:41:01

|

367人浏览过

|

来源于php中文网

原创

使用openpyxl和pandas操作Excel:openpyxl适合精细格式控制,pandas擅长数据分析;读写大型文件时可采用只读/只写模式或分块处理以提升性能。

python中如何操作excel文件_python使用openpyxl/pandas操作excel

Python操作Excel文件,简单来说,就是用代码读写Excel表格。两种常用的库是

openpyxl
pandas
openpyxl
更底层,适合精细控制格式;
pandas
则更适合数据分析和处理,简单粗暴。

解决方案

  1. 使用

    openpyxl

    • 安装:

      pip install openpyxl

      立即学习Python免费学习笔记(深入)”;

    • 读取:

      from openpyxl import load_workbook
      
      # 加载工作簿
      workbook = load_workbook(filename="example.xlsx")
      
      # 选择工作表
      sheet = workbook["Sheet1"]  # 或者 workbook.active 获取活动工作表
      
      # 读取单元格数据
      cell_value = sheet["A1"].value
      print(cell_value)
      
      # 循环读取行
      for row in sheet.iter_rows(min_row=2, max_row=5, min_col=1, max_col=3):
          for cell in row:
              print(cell.value)

      iter_rows
      可以方便地按行读取数据,指定起始和结束的行/列。 注意,
      openpyxl
      的索引是从1开始的,不是从0开始的。 一开始用的时候,经常搞错。

    • 写入:

      from openpyxl import Workbook
      
      # 创建一个新的工作簿
      workbook = Workbook()
      
      # 选择工作表
      sheet = workbook.active
      
      # 写入单元格数据
      sheet["A1"] = "Hello"
      sheet["B2"] = 123
      
      # 保存工作簿
      workbook.save(filename="new_example.xlsx")

      写入数据非常直接,直接赋值即可。 创建新的工作簿也很简单。

    • 格式设置:

      openpyxl
      提供了丰富的格式设置选项,比如字体、颜色、对齐方式等。 这部分比较繁琐,需要查阅文档。

  2. 使用

    pandas

    • 安装:

      pip install pandas

    • 读取:

      import pandas as pd
      
      # 读取Excel文件
      df = pd.read_excel("example.xlsx", sheet_name="Sheet1")
      
      # 打印DataFrame
      print(df)
      
      # 获取特定列
      column_data = df["Column1"]
      print(column_data)

      read_excel
      函数非常强大,可以读取指定的工作表,还可以指定行索引、列索引等。 返回的是一个DataFrame对象,方便进行数据分析。

      易森网络企业版
      易森网络企业版

      如果您是新用户,请直接将本程序的所有文件上传在任一文件夹下,Rewrite 目录下放置了伪静态规则和筛选器,可将规则添加进IIS,即可正常使用,不用进行任何设置;(可修改图片等)默认的管理员用户名、密码和验证码都是:yeesen系统默认关闭,请上传后登陆后台点击“核心管理”里操作如下:进入“配置管理”中的&ld

      下载
    • 写入:

      import pandas as pd
      
      # 创建一个DataFrame
      data = {"Name": ["Alice", "Bob", "Charlie"], "Age": [25, 30, 28]}
      df = pd.DataFrame(data)
      
      # 写入Excel文件
      df.to_excel("new_example.xlsx", sheet_name="Sheet1", index=False)

      to_excel
      函数可以将DataFrame写入Excel文件。
      index=False
      表示不写入行索引。

      pandas
      写入excel,在处理大型数据集时会非常高效。

openpyxl
pandas
,我该选哪个?

选择哪个库取决于你的具体需求。 如果你需要精细控制Excel的格式,或者处理一些特殊的需求,比如合并单元格、插入图片等,那么

openpyxl
更适合你。 如果你主要是进行数据分析和处理,那么
pandas
更方便快捷。
pandas
的DataFrame对象提供了丰富的数据处理方法,可以方便地进行数据清洗、转换、分析等操作。

如何处理Excel中的日期格式?

在用

openpyxl
读取Excel文件时,日期会被读取成datetime对象。

from openpyxl import load_workbook
from datetime import datetime

workbook = load_workbook(filename="example_with_dates.xlsx")
sheet = workbook.active

date_value = sheet["A1"].value

if isinstance(date_value, datetime):
    print(date_value.strftime("%Y-%m-%d")) # 格式化日期
else:
    print(date_value)

pandas
读取时,默认也会尝试将日期识别为datetime对象。 如果读取失败,可以手动指定
parse_dates
参数。

import pandas as pd

df = pd.read_excel("example_with_dates.xlsx", parse_dates=["DateColumn"]) # DateColumn 是包含日期的列名
print(df["DateColumn"].dtype) # 确认是否为datetime64[ns]

如何优化Excel文件读写速度?

对于大型Excel文件,读写速度是一个需要考虑的问题。

  • openpyxl
    可以使用
    read_only
    write_only
    模式来提高读写速度。
    read_only
    模式只能读取数据,不能修改数据;
    write_only
    模式只能写入数据,不能读取数据。

    from openpyxl import load_workbook
    
    # 只读模式
    workbook = load_workbook(filename="large_file.xlsx", read_only=True)
    sheet = workbook.active
    
    for row in sheet.rows:
        for cell in row:
            print(cell.value)
    
    # 只写模式
    from openpyxl import Workbook
    
    workbook = Workbook(write_only=True)
    sheet = workbook.create_sheet()
    
    for i in range(1000):
        row = [i] * 10
        sheet.append(row)
    
    workbook.save("large_file_write_only.xlsx")
  • pandas
    可以使用
    chunksize
    参数来分块读取数据。 这样可以避免一次性将整个文件加载到内存中,从而提高读取速度。

    import pandas as pd
    
    for chunk in pd.read_excel("large_file.xlsx", chunksize=1000):
        print(chunk.head()) # 处理每一块数据

    另外,尽量避免在循环中频繁地读写单元格,可以将数据先存储到内存中,然后一次性写入Excel文件。

相关文章

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

57

2025.12.04

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

339

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

414

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

761

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

349

2025.07.23

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1398

2023.07.25

excel重复项筛选标色
excel重复项筛选标色

excel的重复项筛选标色功能使我们能够快速找到和处理数据中的重复值。本专题为大家提供excel重复项筛选标色的相关的文章、下载、课程内容,供大家免费下载体验。

409

2023.07.31

excel复制表格怎么复制出来和原来一样大
excel复制表格怎么复制出来和原来一样大

本专题为大家带来excel复制表格怎么复制出来和原来一样大相关文章,帮助大家解决问题。

562

2023.08.02

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号