如何使用 Python 读取 Excel 文件:从零开始的超详细教程
“日出东海落西山 愁也一天 喜也一天 遇事不钻牛角尖”
文章目录
- 前言
- 文章有误敬请斧正 不胜感恩!||Day03
- 为什么要用 Python 读取 Excel 文件?
- 准备工作:安装所需工具
- 安装 Python
- 安装 Pandas
- 安装 openpyxl
- 使用 Pandas 读取 Excel 文件
- 什么是 Pandas?
- 读取 Excel 文件的简单示例
- 查看数据的前几行
- 选择特定工作表
- 只读取部分列
- 跳过特定行
- 使用 openpyxl 读取 Excel 文件
- 安装 openpyxl
- 读取 Excel 文件的示例
- 使用 xlwings 操作 Excel 文件
- 安装 xlwings
- 使用 xlwings 读取 Excel
- 选择最适合的工具
- 总结
前言
今天讲什么?:
Excel 文件是我们日常数据处理和管理中常见的工具,尤其是在学校、工作和日常生活中都非常有用。无论是用来做数据统计、制作报表,还是进行分析,Excel 文件都非常方便。而 Python 是一门强大的编程语言,可以帮助我们快速读取和处理 Excel 文件中的数据。这篇文章会详细讲解,如何使用 Python 来读取 Excel 文件。
在数学建模中,C题的数据处理部分更是离不开他。
今天,我们就一起从零开始如何使用 Python 读取 Excel 文件。
文章有误敬请斧正 不胜感恩!||Day03

提示:以下是本篇文章正文内容,
为什么要用 Python 读取 Excel 文件?
在 Excel 文件较少、较简单时,手动打开文件并处理可能是不错的选择。但如果数据量大,或者需要重复进行操作时,用编程来自动处理 Excel 文件就显得非常高效了。Python 是一门功能强大且易学的语言,借助它的各种工具库,我们可以非常轻松地读取、修改甚至创建 Excel 文件。
接下来,我会一步步教大家如何使用 Python 读取 Excel 文件。
准备工作:安装所需工具
在开始之前,我们需要先安装 Python 和一些必要的工具库。Python 自身并不能直接读取 Excel 文件,但借助一些强大的库,我们可以轻松实现这个目标。接下来介绍最常用的工具库。
安装 Python
首先,如果你的电脑还没有安装 Python,你可以去 Python 官方网站 下载并安装。

安装 Pandas
Pandas 是一个非常流行的 Python 库,它让我们可以像操作 Excel 一样操作数据。要使用 Pandas,首先需要安装它。打开命令行窗口(Windows 的 CMD 或者 macOS 的 Terminal),然后输入以下命令进行安装:
pip install pandas

或者也可以在IDE中找到

安装 openpyxl
有时候,Pandas 需要借助 openpyxl 来处理 Excel 文件,尤其是 .xlsx 格式的文件,所以我们也需要安装它:
pip install openpyxl

安装好这些工具后,我们就可以开始编写代码来读取 Excel 文件了!


使用 Pandas 读取 Excel 文件
什么是 Pandas?
Pandas 是一个专门用来处理数据的库。它非常适合用于处理 Excel 这样的表格数据。读取 Excel 文件后,Pandas 会把数据转换成类似于表格的格式,称为 DataFrame,让我们可以轻松地进行查看、修改和分析。
读取 Excel 文件的简单示例
假设你有一个名为 data.xlsx 的 Excel 文件,里面有一些数据。我们可以通过以下代码来读取这个文件:

import pandas as pd # 引入 pandas 库# 使用 pandas 读取 Excel 文件
df = pd.read_excel('data.xlsx')# 输出读取的数据
print(df)
这段代码的工作原理很简单:
- 首先,我们引入了
pandas库,并将它命名为pd以方便调用。 - 使用
pd.read_excel('文件名')读取 Excel 文件。文件名可以是相对路径,也可以是绝对路径。 df是读取后的数据对象,称为 DataFrame。我们可以把它理解为一个电子表格或表格数据。- 使用
print(df)可以输出整个表格。

查看数据的前几行
有时候,Excel 文件可能会非常大,直接打印全部内容不太方便。我们可以使用 .head() 方法来只查看前几行数据:
print(df.head()) # 查看前5行数据
选择特定工作表
如果 Excel 文件里有多个工作表,Pandas 默认会读取第一个工作表。如果你想读取其他工作表,可以使用 sheet_name 参数指定工作表的名称:
df = pd.read_excel('data.xlsx', sheet_name='Sheet2')
这里,Sheet2 是工作表的名字。如果你不知道工作表的名字,也可以用索引数字,比如第一个工作表是 0,第二个工作表是 1,依此类推:
df = pd.read_excel('data.xlsx', sheet_name=1) # 读取第二个工作表
只读取部分列
如果 Excel 文件中有很多列,但你只需要其中的几列数据,可以通过 usecols 参数选择特定的列。例如:
df = pd.read_excel('data.xlsx', usecols=['A', 'C']) # 只读取 A 列和 C 列
这样你就可以只读取那些对你有用的列,省去不必要的内容。
跳过特定行
有时候,Excel 文件的前几行可能是标题或者一些无用的信息。你可以使用 skiprows 参数跳过这些行:
df = pd.read_excel('data.xlsx', skiprows=2) # 跳过前2行
这就会从第 3 行开始读取数据。
使用 openpyxl 读取 Excel 文件
Pandas 是最常用的工具,但如果,想更灵活地读取和修改 Excel 文件内容,openpyxl 是另一个不错的选择。它可以直接操作 Excel 文件里的数据、样式、公式等。
安装 openpyxl
如果你还没有安装 openpyxl,可以通过以下命令来安装:
pip install openpyxl
读取 Excel 文件的示例
以下是使用 openpyxl 读取 Excel 文件的简单代码:
import openpyxl# 打开 Excel 文件
wb = openpyxl.load_workbook('data.xlsx')# 选择一个工作表
sheet = wb['Sheet1']# 读取某个单元格的值
cell_value = sheet['A1'].value
print(cell_value)# 读取多行数据
for row in sheet.iter_rows(min_row=1, max_row=5, values_only=True):print(row)
load_workbook用于打开 Excel 文件。sheet['A1'].value用于获取 A1 单元格的值。iter_rows用于遍历多个单元格,比如上面的代码会打印前 5 行的数据。
使用 xlwings 操作 Excel 文件
如果我们需要与 Excel 应用程序直接交互(比如让 Excel 打开、显示并处理数据),或者类似操作。我们就可以使用 xlwings 这个库。
它甚至可以运行 VBA 宏,非常适合在需要大量操作 Excel 时使用。
安装 xlwings
pip install xlwings
使用 xlwings 读取 Excel
以下是使用 xlwings 读取 Excel 文件的简单代码:
import xlwings as xw# 启动 Excel 应用程序
app = xw.App(visible=False) # 设置为 False 时,Excel 不会在屏幕上显示# 打开 Excel 文件
wb = xw.Book('data.xlsx')# 选择工作表
sheet = wb.sheets['Sheet1']# 读取 A1 单元格的值
cell_value = sheet.range('A1').value
print(cell_value)# 关闭 Excel
wb.close()
app.quit()
xw.App(visible=False)可以让 Excel 在后台运行,而不显示在桌面上。如果你想看到 Excel 操作,可以把visible改为True。range('A1').value获取 A1 单元格的值。- 在我们实际应用时,就应该根据我们自己的情况,来选定。
选择最适合的工具
在 Python 中,不同的工具适合不同的场景,读取 Excel 文件有很多种方式,例如:
-
Pandas:万金油:适合大多数数据分析任务,快速读取和处理 Excel 数据。
-
openpyxl:复杂处理:适合需要对 Excel 文件进行复杂操作(如修改样式、编辑单元格)的场景。
-
xlwings:交互大王:适合与 Excel 应用程序交互,特别是在需要打开 Excel 并操作时。
总结
通过本文的介绍,我们学习了使用 Python 读取 Excel 文件的几种常用方法。
不管是在I/O中的简单的数据读取,还是复杂的 Excel 操作,Python 都能提供强大的工具帮助你处理这些任务。
哈哈
我们python真是世界上最好的语言.java
除此之外,根据我们的需求选择合适的库,既能提高效率,也能避免手动操作中的繁琐和错误。
希望这篇文章能帮助到大家来更好地掌握 Python 读取 Excel
文章如有错误是小生才疏学浅,还望各位看官海涵!
有问题欢迎各位多多评论交流。
我们下一篇再见!

相关文章:
如何使用 Python 读取 Excel 文件:从零开始的超详细教程
“日出东海落西山 愁也一天 喜也一天 遇事不钻牛角尖” 文章目录 前言文章有误敬请斧正 不胜感恩!||Day03为什么要用 Python 读取 Excel 文件?准备工作:安装所需工具安装 Python安装 Pandas安装 openpyxl 使用 Pandas 读取 Excel 文件什么是 …...
仕考网:公务员笔试和面试哪个难?
公务员笔试和面试哪个难?二者之间考察的方向不同,难度也是不同的。 笔试部分因其广泛的知识点和有限的考试时间显得难度更高一些,在笔试环节中,考生需在有限的时间内应对各种问题,而且同时还要面对激烈的竞争,在众多…...
C++知识点总结(55):时间优化
时间优化 一、调试方法1. 输出调试2. 构造样例 二、时间优化1. 前缀和1.1 概念1.2 例题Ⅰ 区间最多数码Ⅱ 双字母字符串Ⅲ Wandering...Ⅳ 数对数目 2. 排序例题选择排序过程 一、调试方法 1. 输出调试 cout 是一个强大的调试工具,可以帮助我们查看程序的状态和变…...
GitHub每日最火火火项目(9.7)
项目名称:polarsource / polar 项目介绍:polar 是一个开源的项目,它是 Lemon Squeezy 的替代方案,具有更优惠的价格。该项目旨在让开发者能够凭借自己的热情进行编码并获得报酬。通过使用 polar,开发者可以更轻松地实现…...
11Python的Pandas:可视化
Pandas本身并没有直接的可视化功能,但它与其他Python库(如Matplotlib和Seaborn)无缝集成,允许你快速创建各种图表和可视化。这里是一些使用Pandas数据进行可视化的常见方法: 1. 使用Matplotlib Pandas中的plot()方法…...
【周易哲学】生辰八字入门讲解(二)
😊你好,我是小航,一个正在变秃、变强的文艺倾年。 🔔本文讲解【周易哲学】生辰八字入门讲解,期待与你一同探索、学习、进步,一起卷起来叭! 目录 十神十神判断十神类象十神与五行案例 地支藏干藏…...
传统CV算法——基于Opencv的多目标追踪算法
基于 OpenCV 的跟踪算法有多种,每种算法都有其特定的应用场景和优缺点。以下是一些常见的基于 OpenCV 的目标跟踪算法: 1. BOOSTING 跟踪器 描述:基于 AdaBoost 算法的跟踪器。它是一种早期的跟踪算法,使用的是基于弱分类器的强…...
人生苦短我用Python excel转csv
人生苦短我用Python excel转csv 前言准备工作pandas库主要类和方法ExcelFile 类DataFrame 类read_excel 函数to_csv 函数 示例 前言 Excel 文件和csv文件都是常用的电子表格文件格式,其中csv格式更便于用于数据交换和处理。本文使用pandas库将Excel文件转化为csv文…...
Web2和Web3笔记
KimiAI: Web2和Web3是互联网发展的不同阶段,它们代表了不同的技术、理念和用户交互方式。 Web2: Web2通常指的是第二代互联网,它始于2000年代中期,以用户生成内容和社交网络的兴起为标志。 在Web2中,用户不仅是内容的消…...
单元测试 Mock不Mock?
文章目录 前言单元测试没必要?Mock不Mock?什么是Mock?Mock的意义何在? 如何Mock?应该Mock什么?Mock 编写示例 总结 前言 前段时间,我们团队就单元测试是否采用 Mock 进行了一番交流,各有各的说法。本文就单元测试 Mock不Mock…...
常用排序算法(上)
目录 前言: 1.排序的概念及其运用 1.1排序的概念 1.2排序运用 1.3 常见的排序算法 2.常见排序算法的实现 2.1 堆排序 2.1 1 向下调整算法 2.1 2 建堆 2.1 3 排序 2.2 插入排序 2.1.1基本思想: 2.1.2直接插入排序: 2.1.3 插…...
【从问题中去学习k8s】k8s中的常见面试题(夯实理论基础)(二十六)
本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》:python零基础入门学习 《python运维脚本》: python运维脚本实践 《shell》:shell学习 《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战 《k8…...
小程序的页面跳转方式
102. 小程序的页面跳转方式 小程序是一种快速发展的应用形式,为用户提供了便捷的功能和交互体验。其中,页面跳转是小程序中常用的功能之一,本文将介绍小程序的页面跳转方式,并提供代码示例,帮助读者更好地理解和实现页…...
第 21 章 DOM 操作表格及样式
第 21 章 DOM 操作表格及样式 1.操作表格 2.操作样式 DOM 在操作生成 HTML 上,还是比较简明的。不过,由于浏览器总是存在兼容和陷阱,导致最终的操作就不是那么简单方便了。本章主要了解一下 DOM 操作表格和样式的一些知识。 一࿰…...
vc-align源码分析 -- ant-design-vue系列
vc-align源码分析 源码地址:https://github.com/vueComponent/ant-design-vue/tree/main/components/vc-align 1 基础代码 1.1 名词约定 需要对齐的节点叫source,对齐的目标叫target。 1.2 props 提供了两个参数: align:对…...
计算机网络(四) —— 简单Tcp网络程序
目录 一,服务器初始化 1.0 部分文件代码 1.1 关于Tcp协议 1.2 创建和绑定套接字 1.3 监听 二,服务器启动 2.1 获取连接 2.2 提供服务 2.3 客户端启动源文件 Main.cc 二,客户端编写 2.1 关于Tcp客户端 2.2 客户端代码 2.3 效果…...
简单的Linux Ftp服务搭建
简单的Linux FTP服务搭建 1.需求 公司有一个esb文件传输代理,其中我们程序有文件传输功能,需要将本地文件传输到esb文件代理服务器上,传输成功之后发送http请求,告知esb将固定文件进行传输到对应外围其他服务的文件目录中&#…...
SQL的高级查询练习知识点(day24)
目录 1 学习目标 2 基础查询 2.1 语法 2.2 例子 3 条件查询 3.1 含义 3.2 语法 3.3 条件表达式 3.3.1 条件运算符 3.3.2 例子 3.4 逻辑表达式 3.4.1 逻辑运算符 3.4.2 例子 3.5 模糊查询 3.5.1 概述 3.5.2 例子 4 DISTINCT关键字 4.1 含义 4.2 例子 5 总结…...
Python条件表达式优化的10个实例
Python 中的条件表达式(也称为三元运算符)是一种简洁的语法,用于在单个表达式中执行 if-else 逻辑。虽然它们本身并不直接“优化”代码的执行速度,但它们可以使代码更加简洁、易读,并且有助于避免不必要的嵌套或复杂的…...
oatpp apiclient 客户端get,post请求python fastapi demo
最新用fastapi搞了个服务端,python功能太强了,就是环境不好弄,弄好后,不要轻易换python版本,不要装多个python版本 前面搞了个oatpp webapi服务端,现在要用客户端,为什么用opatpp客户端,因为他不再带其他库了 demo: 我的请求比较简单,就是向python 的 fastapi服务端…...
【Python】 -- 趣味代码 - 小恐龙游戏
文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...
7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...
label-studio的使用教程(导入本地路径)
文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...
vue3 定时器-定义全局方法 vue+ts
1.创建ts文件 路径:src/utils/timer.ts 完整代码: import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...
CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云
目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...
使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...
Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析
Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析 一、第一轮提问(基础概念问题) 1. 请解释Spring框架的核心容器是什么?它在Spring中起到什么作用? Spring框架的核心容器是IoC容器&#…...
【Go语言基础【13】】函数、闭包、方法
文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数(函数作为参数、返回值) 三、匿名函数与闭包1. 匿名函数(Lambda函…...
PostgreSQL——环境搭建
一、Linux # 安装 PostgreSQL 15 仓库 sudo dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-$(rpm -E %{rhel})-x86_64/pgdg-redhat-repo-latest.noarch.rpm# 安装之前先确认是否已经存在PostgreSQL rpm -qa | grep postgres# 如果存在࿰…...
