前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python处理Excel数据的方法[通俗易懂]

Python处理Excel数据的方法[通俗易懂]

作者头像
全栈程序员站长
发布于 2022-11-18 09:32:39
发布于 2022-11-18 09:32:39
6.1K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

Python处理Excel数据的方法

当Excel中有大量需要进行处理的数据时,使用Python不失为一种便捷易学的方法。接下来,本文将详细介绍多种Python方法来处理Excel数据。

Excel处理经常用于数据可视化,那么如何利用提取到的Excel数据绘图呢? 本文搭配Python绘图 \ 数据可视化一起使用效果更佳。

电子表格格式

我们在日常工作中常常见到各种后缀的电子表格,例如最常见的xlsx以及较为常见的csv、xls等格式的表格。同样是电子表格,它们之间有什么区别吗?

xls为Excel早期表格格式。

xls格式是Excel2003版本及其以前版本所生成的文件格式。 其最大的特点就是:仅有65536行、256列。因此规模过大的数据不可以使用xls格式读写。

xlsx为Excel2007及其之后的表格格式,也是现在Excel表格的主流格式。

与xls相比,它可以存储1048576行、16384列数据,存储相同数据,xlsx格式要比xls格式文件要小得很多。

CSV为逗号分隔值文件。

CSV逗号分隔值文件格式,其以纯文本形式存储表格数据(数字和文本),可以用Excel软件打开。

xlrd 模块既可读取 xls 文件也可读取 xlsx 文件;xlwt只可写 xlsx 文件;openpyxl 可以读写 xlsx 文件;pandas 可以同时读写 xls、xlsx 文件。

经评论区提醒发现,xlrd 2.0.0 及更高版本只能读取 .xls 文件,建议使用其他库读取 .xlsx文件 或 安装 xlrd 早期版本。

1.使用 xlrd 来处理;

xlrd命令

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xlrd
book = xlrd.open_workbook('excelFile.xlsx')  # 获取工作簿对象
names = book.sheet_names()  # 获取所有工作表名称结果为列表
mySheets = book.sheets()                 # 获取工作表list。
sheet = mySheets[0]                    # 通过索引顺序获取。
sheet = book.sheet_by_index(0)         # 通过索引顺序获取。
sheet = book.sheet_by_name(u'Sheet1')  # 通过名称获取 u表示后面字符串以 Unicode 格式 进行编码,一般用在中文字符串前面,以防乱码
# 获取行数和列数
nrows = sheet.nrows
ncols = sheet.ncols
# 获取一行和一列
row = sheet.row_values(i)               # i是行数,从0开始计数,返回list对象。
col = sheet.col_values(i)               # i是列数,从0开始计数,返回list对象。
# 读取单元格数据
cell = sheet.cell_value(i, j)      # 直接获取单元格数据,i是行数,j是列数,行数和列数都是从0开始计数。
cell = sheet.cell(i,j).value    

示例1:Python读取Excel文件特定数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xlrd
data = xlrd.open_workbook('excelFile.xlsx') # 打开xlsx文件
table = data.sheets()[0] # 打开第一张表
nrows = table.nrows # 获取表的行数
# 循环逐行输出
for i in range(nrows):
if i == 0: # 跳过第一行
continue
print(table.row_values(i)[:5]) # 取前五列数据

示例2:Python读取Excel文件所有数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xlrd
workbook = xlrd.open_workbook('excelFile.xlsx')  # 打开一个xlsx文件
worksheets = workbook.sheet_names()  # 抓取所有sheet页的名称
print('worksheets is %s' %worksheets)
worksheet1 = workbook.sheet_by_name(u'Sheet1')  # 如果存在sheet1文件则定位到sheet1
""" #遍历所有sheet对象 for worksheet_name in worksheets: worksheet = workbook.sheet_by_name(worksheet_name) """
# 遍历sheet1中所有行row
num_rows = worksheet1.nrows
for curr_row in range(num_rows):
row = worksheet1.row_values(curr_row)
print('row%s is %s' %(curr_row,row))
# 遍历sheet1中所有列col
num_cols = worksheet1.ncols
for curr_col in range(num_cols):
col = worksheet1.col_values(curr_col)
print('col%s is %s' %(curr_col,col))
# 遍历sheet1中所有单元格cell
for rown in range(num_rows):
for coln in range(num_cols):
cell = worksheet1.cell_value(rown,coln)
print(cell)

2.使用 xlwt 来处理;

使用xlwt模块写入Excel文件

xlwt模块只能写xls文件,不能写xlsx文件(写xlsx程序不会报错,但最后文件无法直接打开,会报错)。

默认保存在py文件相同路径下,如果该路径下有相同文件,会被新创建的文件覆盖。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xlwt
myWorkbook = xlwt.Workbook()  # 创建Excel工作薄 若要写入中文则添加参数encoding = 'utf-8'
sheet = myWorkbook.add_sheet('New_Sheet')  # 创建Excel工作表
##sheet.write(m,n,'内容1') # 向单元格写入内容
myStyle = xlwt.easyxf('font: name Times New Roman, color-index red, bold on', num_format_str='#,##0.00')   # 数据格式
sheet.write(1, 1, 2022, myStyle)
sheet.write(2, 0, 1)                          # 写入A3,数值等于1
sheet.write(2, 1, 1)                          # 写入B3,数值等于1
sheet.write(2, 2, xlwt.Formula("A3+B3"))      # 写入C3,数值等于2A3+B3,xlwt支持写入公式
# 保存
myWorkbook.save('excelFile.xls')

示例:新建excel文件并写入数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xlwt
# 创建workbook和sheet对象
workbook = xlwt.Workbook() # 注意Workbook的开头W要大写
sheet1 = workbook.add_sheet('sheet1',cell_overwrite_ok=True)
sheet2 = workbook.add_sheet('sheet2',cell_overwrite_ok=True)
# 向sheet页中写入数据
sheet1.write(0,0,'sheet1')
sheet1.write(0,1,'sheet1_content')
sheet2.write(0,0,'sheet2')
sheet2.write(1,2,'sheet2_content')
# 保存该excel文件,有同名文件时直接覆盖
workbook.save('test.xls')
print('创建excel文件完成!')

3.使用 openpyxl 来处理;

openpyxl可以对excel文件进行读写操作

openpyxl模块可实现对excel文件的读、写和修改,只能处理xlsx文件,不能处理xls文件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from openpyxl import Workbook
from openpyxl import load_workbook
from openpyxl.writer.excel import ExcelWriter
wb = load_workbook(u"成绩单.xlsx")
sheetnames = wb.sheetnames # 获得表单名字 
print(sheetnames)
title = sheet1.title  # 获取工作表名称
rows = sheet1.max_row  # 获取工作表行数
cols = sheet1.max_column  # 获取工作表列数
sheet = wb[sheetnames[0]]
print(sheet.cell(row=3,column=3).value)
sheet['A1'] = 'grade'
wb.save(u"成绩单_new.xlsx")  # 修改元素值并另存为xlsx文件
sheet = wb.active  # 获取活动表
print(sheet)
print(sheet.dimensions)     # 获取表格的尺寸大小
cell1 = sheet['B7']         # 获取B7单元格的数据
print(cell1.value)  # cell1.value获取单元格B7中的值
print(sheet['a2'].value)   # 使用excel单元格的表示法,字母不区分大小写 获取第2行第1列的数据
print(cell.value, cell.row, cell.column, cell.coordinate)  # 获取某个格子的行数、列数以及坐标
cell = sheet['A1:A5']  # 使用sheet['A1:A5']获取A1A5的数据
##print(cell)
# 打印A1A5的数据
for i in cell:
for j in i:
print(j.value)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# openpyxl读取excel文件
book = openpyxl.Workbook()  # 创建工作簿 如果写入中文为乱码,可添加参数encoding = 'utf-8'
sheet = book.create_sheet('Sheet_name',0)  # 创建工作表,0表示创建的工作表在工作薄最前面
sheet.cell(m,n,'content1')  # 向单元格写入内容:
book.save('excelFile')  # 保存工作簿,默认保存在py文件相同路径下,如果该路径下有相同文件,会被新创建的文件覆盖。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# openpyxl修改excel文件
sheet.insert_rows(m)和sheet.insert_cols(n)分别表示在第m行、第n列前面插入行、列
sheet.delete_rows(m)和sheet.delete_cols(n)分别表示删除第m行、第n列
修改单元格内容:sheet.cell(m,n) = '内容1'或者sheet['B3'] = '内容2' 
在最后追加行:sheet.append(可迭代对象)

4.使用Pandas库来处理excel数据

Pandas 可以从各种文件格式比如 CSV、JSON、SQL、Microsoft Excel 导入数据。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pd
mydata = { 

'sites': ["SZ", "BJ", "SS"],
'number': [1, 2, 3]
}
myvar = pd.DataFrame(mydata)
print(myvar)
''' output: sites number 0 SZ 1 1 BJ 2 2 SS 3 '''
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pd
file_path = r'example.xlsx'
df = pd.read_excel(file_path, sheet_name = "test") # sheet_name不指定时默认返回全表数据
print(df)  # 打印表数据,如果数据太多,会略去中间部分
print(df.head())  # 打印头部数据,仅查看数据示例时常用
print(df.columns)  # 打印列标题
print(df.index)  # 打印行
print(df["ave"])   # 打印指定列
# 描述数据
print(df.describe())

写excel

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from pandas import DataFrame
data = { 
 'name': ['zs', 'ls', 'ww'], 'age': [11, 12, 13], 'gender': ['man', 'man', 'woman']}
df = DataFrame(data)
df.to_excel('new.xlsx')

修改excel–以修改原Excel文件中gender列数据为例,把girl修改为female,boy修改为male:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pd
from pandas import DataFrame
file_path = r'test.xlsx'
df = pd.read_excel(file_path)
df['gender'][df['gender'] == 'girl'] = 'female'
df['gender'][df['gender'] == 'boy'] = 'male'
print(df)
DataFrame(df).to_excel(file_path, sheet_name='Sheet1', index=False, header=True)
df.loc[row_index] = [val1, val2, val3]  # 新增行
df[colo_name] = None  # 新增列

示例1:读取excel数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 导入pandas模块
import pandas as pd
# 直接默认读取到这个Excel的第一个表单
sheet = pd.read_excel('test.xlsx')
# 默认读取前5行数据
data=sheet.head()
print("获取到所有的值:\n{0}".format(data)) # 格式化输出
# 也可以通过指定表单名来读取数据
sheet2=pd.read_excel('test.xlsx',sheet_name='test')
data2=sheet2.head() # 默认读取前5行数据
print("获取到所有的值:\n{0}".format(data2)) # 格式化输出

示例2:操作Excel中的行列

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 导入pandas模块
import pandas as pd
sheet=pd.read_excel('test.xlsx')  # 这个会直接默认读取到这个Excel的第一个表单
# 读取制定的某一行数据:
data=sheet.loc[0].values   # 0表示第一行 这里读取数据并不包含表头
print("读取指定行的数据:\n{0}".format(data))
# 读取指定的多行:
data2=sheet.loc[[0,1]].values
print("读取指定行的数据:\n{0}".format(data2))
# 获取行号输出:
print("输出行号列表",sheet.index.values)
# 获取列名输出:
print("输出列标题",sheet.columns.values)

其他

当收到的文件既有xls,又有xlsx时,先转换为统一格式再做统计修改更方便。

需要用到pywin32库,方法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import win32com.client as win32
fname = r"C:\User\Desktop\test.xlsx"
excel = win32.gencache.EnsureDispatch('Excel.Application')
wb = excel.Workbooks.Open(fname)
# wb.SaveAs(fname+"x", FileFormat = 51) #FileFormat = 51 is for .xlsx extension
wb.SaveAs(fname[:-1], FileFormat = 56)      #FileFormat = 56 is for .xls extension
wb.Close()
excel.Application.Quit()

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/210057.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月25日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
python 操作excel(附案例)
常见读写excel 的库有以下 几个(附案例) xlwt xlrd xlutils openpyxl pandas xlwt 主要用于对xls文件进行写入操作 import xlwt #创建workbook book = xlwt.Workbook() #添加sheet页 table = book.add_sheet('Over', cell_overwrite_ok=True) sheet = book.add_sheet('测试表') print(type(table)) print(table)
Python研究者
2020/09/28
7750
可能是全网最完整的 Python 操作 Excel库总结!
在之前的办公自动化系列文章中,我已经对Python操作Excel的几个常用库openpyxl、xlrd/xlwt、xlwings、xlsxwriter等进行了详细的讲解。
小F
2021/03/18
9.6K0
可能是全网最完整的 Python 操作 Excel库总结!
Python操作Excel
常用的方式 常用的读写Excel的库: pandas openpyxl xlrd/xlwt/xlutils 使用它们都能够达到读写Excel的目的,但它们的侧重点又略有不同。 具体如下: pandas:数据处理最常用的分析库之一,可以读取各种各样格式的数据文件,一般输出dataframe格式,功能强大 openpyxl:主要针对xlsx格式的excel进行读取和编辑 xlrd库:从excel中读取数据,支持xls、xlsx xlwt库:对excel进行修改操作,不支持对xlsx格式的修改 xlutils库:
码客说
2022/01/17
1.5K0
Python自动化:Python操作Excel的多种方式Pandas+openpyxl+xlrd
使用pandas操作Excel文件主要涉及读取(read_excel)和写入(to_excel)两个主要操作。
小白的大数据之旅
2024/11/20
1.1K0
【4】python读写文件操作---详细讲解!
python读写文件详细讲解! 1.操作xls格式的表格文件: 读取:xlrd 写入:xlwt 修改(追加写入):xlutils 2.操作xlsx格式的表格文件: 读取/写入:openpyxl 一. 读取Excel 1. 导入读取库 import xlrd 2. 打开Excel文件读取数据 data = xlrd.open_workbook('xxx.xls') 3. 获取一个工作表 table = data.sheets()[0] #通过索引顺序获取 table = data
汀丶人工智能
2022/12/21
1.3K0
【4】python读写文件操作---详细讲解!
Python开发 之 Python3读写Excel文件(较全)[通俗易懂]
于是我找到了xlsxwriter这个模块,它生成的文件后缀名为.xlsx,最大能够支持1048576行数据,16384列数据
全栈程序员站长
2022/11/11
2.3K0
Python开发 之 Python3读写Excel文件(较全)[通俗易懂]
Python从0到100(二十一):用Python读写Excel文件
Excel是Microsoft(微软)为使用Windows和macOS操作系统开发的一款电子表格软件。Excel凭借其直观的界面、出色的计算功能和图表工具,再加上成功的市场营销,一直以来都是最为流行的个人计算机数据处理软件。当然,Excel也有很多竞品,例如Google Sheets、LibreOffice Calc、Numbers等,这些竞品基本上也能够兼容Excel,至少能够读写较新版本的Excel文件,当然这些不是我们讨论的重点。掌握用Python程序操作Excel文件,可以让日常办公自动化的工作更加轻松愉快,而且在很多商业项目中,导入导出Excel文件都是特别常见的功能。
是Dream呀
2024/05/28
3250
Python办公自动化之Excel做表自动化:全网最全,看这一篇就够了!
官方文档:https://xlrd.readthedocs.io/en/latest/
Python小二
2020/09/08
8K0
Python办公自动化之Excel做表自动化:全网最全,看这一篇就够了!
python高手之路python处理ex
用python来自动生成excel数据文件。python处理excel文件主要是第三方模块库xlrd、xlwt、xluntils和pyExcelerator,除此之外,python处理excel还可以用win32com和openpyxl模块。
py3study
2020/01/13
1K0
Python操作Excel模块,你猜哪家强?
导读:Python操作excel的模块简直不要太多,今天就为大家比较下各模块之间的优缺点。
IT阅读排行榜
2020/02/20
1.9K0
Python操作Excel模块,你猜哪家强?
Python读取excel三大常用模块到底谁最快,附上详细使用代码
之前分享过python调用过ppt和word,作为一家人的excel当然要整整齐齐的安排上
行哥玩Python
2020/07/14
86.7K1
不吹不黑!Python办公自动化,全网最全整理!
官方文档:https://xlrd.readthedocs.io/en/latest/
释然IT杂谈
2023/08/18
1.6K0
不吹不黑!Python办公自动化,全网最全整理!
python3爬虫初探(六)之EXCEL
 在爬取数据之后,数据的保存就成为一个新的问题,一般不太大的的数据存储到EXCEL就可以了。这里介绍一个python的第三方库——xlsxwriter.
py3study
2020/01/10
8620
python3爬虫初探(六)之EXCEL
python操作Excel,你觉得哪个库更好呢?
每一个Excel数据文件从上至下分为三个层级的对象: workbook: 每一个Excel文件就是一个workbook。 sheet: 每一个workbook中可以包含多个sheet,具体就对应Excel中我们在左下脚所看到的“sheet1”,“sheet2”等。 cell: 每一个sheet就是我们通常所看到的一个表格,可以含有m行,n列,每个确定的行号,列号所对应的一个格子就是一个cell。
星星在线
2018/08/21
12.6K0
python操作Excel,你觉得哪个库更好呢?
[306]python操作excel表格(xlrd/xlwt)
python操作excel主要用到xlrd和xlwt这两个库,即xlrd是读excel,xlwt是写excel的库。可从这里下载https://pypi.python.org/pypi。下面分别记录python读和写excel.
周小董
2022/04/12
2.7K0
[306]python操作excel表格(xlrd/xlwt)
Python实例篇:自动操作Excel文件(既简单又特别实用)
大家平时在工作与学习中都会操作到Excel文件格式,特别是很多数据的时候,靠人力去识别操作非常容易出错。今天就带大家用Python来处理Excel文件,让你成为一个别人眼中的秀儿~
润森
2022/09/22
2.7K0
利用Python读取和修改Excel文件(包括xls文件和xlsx文件)——基于xlrd、xlwt和openpyxl模块
本文介绍一下使用Python对Excel文件的基本操作,包括使用xlrd模块读取excel文件,使用xlwt模块将数据写入excel文件,使用openpyxl模块读取写入和修改excel文件。
全栈程序员站长
2022/09/02
10K0
利用Python进行读写Excel文件
Python作为一种脚本语言相较于shell具有更强大的文件处理能力,一般shell在处理纯文本文件时较为实用,而对特殊文件的处理如excel表格则Python会更得心应手,主要体现在它可以调用很多第三方功能包来实现我们想要的功能,Python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别:
用户7886150
2020/12/22
7080
关于python读写excel表格的两三个例子
关于flask的事情遇到一些麻烦,暂时先搁置几天;最近工作总是在处理数据,出于偷懒的因素,最反感重复性的工作,因此当几十个上百个表哥表姐摆在面前的时候,也不太想麻烦别人,总想着用批处理的方式来解决,这不就遇到了一些问题嘛。
python与大数据分析
2022/03/11
9570
关于python读写excel表格的两三个例子
python–xlsx文件的读写[通俗易懂]
最近碰到一个问题,需要读取后缀为xlsx的文件,因此在此总结一下python对于xlsx文件的读写。 一般如果是后缀xls的话,用xlwt和xlrd进行读写;而后缀是xlsx的话,用openpyxl进行读写。在此主要介绍openpyxl库对xlsx的读写。 参考链接:python之openpyxl模块
全栈程序员站长
2022/09/02
1.6K0
推荐阅读
相关推荐
python 操作excel(附案例)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验