Python笔记一之excel的读取
本文首发于公众号:Hunter后端
原文链接:Python笔记一之excel的读取
这里我常用的 python 对于 excel 的读取库有两个,一个是 xlsxwriter 用于操作 excel 的写入,一个是 xlrd 用于 excel 文件的读取。
使用的库的版本如下:
- xlsx==1.2.6
- xlrd==1.1.0
xlsxwriter 写入 excel
新建一个 excel
import xlsxwriter
path = "/Users/hunter/xxx.xlsx"
wb = xlsxwriter.Workbook(path)
添加一个 sheet:
# 定义 sheet 的名称
sheet_name = "sheet_name"
# 添加一个 sheet 页
sheet_1 = wb.add_worksheet(sheet_name)
sheet 表格数据的写入
sheet 的表格数据有几种方式,一种是通过 x, y 这种坐标轴定位的方式,从左上角开始,左上角也就是 'A1' 的位子为 (0, 0)。
比如我们想要在左上角写入数据:
sheet1.write(0, 0, "A1数据")
如果我们想要在第二行,第三列写入数据:
sheet1.write(1, 2, "C2数据")
另一种是通过 excel 的单元格名称来定位写入,比如 'A1','D4'这种:
sheet1.write("A1", "A1数据")
sheet1.write("F2", "F2数据")
批量写入
除了单个单元格的数据写入,我们还可以通过某个起始单元格来批量写入。
批量写入可以从横向写入,也可以从纵向写入。
比如如果想要从 C2 单元格开始,横向写入 python,java,JS 三条数据,可以如下操作:
sheet1.write_row("C2", ["python", "java", "JS"])
也可以通过 i, j 的定位方式来操作,比如从 "C3" 开始往后写入:
sheet1.write_row(2, 2, ["python", "java", "JS"])
上面的 write_row() 方法是横向写入,从起始位置横向开始写,如果是纵向,那就使用 write_column()
保存
然后将这个 excel 保存:
wb.close()
xlrd 读取 excel
注意: 安装 xlrd 的时候不要安装默认的版本,当前默认的最新版本不能解析 xlsx 文件,我这里选择的是 xlrd==1.0.0
使用 xlrd 从 excel 中读取数据的操作方式如下:
获取 excel
import xlrd
path = "/Users/hunter/xxx.xlsx"
workbook = xlrd.open_workbook(path)
获取 sheet
获取 sheet 对象列表:
sheet_list = workbook.sheets()
获取所有的 sheet 的名称列表:
sheet_name_list = workbook.sheet_names()
根据索引获取单个 sheet:
i = 0
sheet = workbook.sheet_by_index(i)
获取单元格数据
如果直接获取单元格数据,可以通过坐标轴的 x, y 的方式来定位获取,其中左上角是 (0, 0)。
比如我们想获取 (0, 0) 位子的数据,也就是 'A1' 的单元格,我们可以:
cell = sheet.cell(0, 0)
获取到的是这个单元格对象,如果想要获取其中的值,需要对 cell 对象再取值:
print(cell.value)
也可以直接使用取值的方法:
print(sheet.cell_value(0, 0))
获取行列数据
上面是通过单元格单个获取数据,我们可以单独获取行和列的数据,比如获取第二行的单元格:
row_2 = sheet.row(1)
上面获取到的数据是一个对象列表,每个元素都是一个个的单元格 cell,也就是我们上面通过 cell() 函数获取到的对象。
如果是想直接取值,则可以:
row_value_2 = sheet.row_values(1)
返回的是一个列表,元素是该行单元的 value 值
查看该行长度:
row_value_2_len = sheet.row_len(1)
获取 sheet 的总行数:
nrows = sheet.nrows
根据列获取数据将函数的 row 换成 col 即可,比如获取第二列的数据:
col_value_2 = sheet.col_values(1)
如果想获取更多相关文章,可扫码关注阅读:

Python笔记一之excel的读取的更多相关文章
- python openpyxl模块实现excel的读取,新表创建及原数据表追加新数据
当实际工作需要把excel表的数据读取出来,或者把一些统计数据写入excel表中时,一个设计丰富,文档便于寻找的模块就会显得特别的有吸引力,本文对openpyxl模块的一些常见用法做一些记录,方便工作 ...
- 记录python接口自动化测试--从excel中读取params参数传入requests请求不生效问题的解决过程(第七目)
在第六目把主函数写好了,先来运行一下主函数 从截图中可以看到,请求参数打印出来了,和excel中填写的一致 但是每个接口的返回值却都是400,提示参数没有传进去,开始不知道是什么原因(因为excel中 ...
- 用python在excel中读取与生成随机数写入excel中
今天是我第一次发博客,就关于python在excel中的应用作为我的第一篇吧. 具体要求是:在一份已知的excel表格中读取学生的学号与姓名,再将这些数据放到新的excel表中的第一列与第二列,最后再 ...
- 【转】Python xlrd、xlwt、xlutils读取、修改Excel文件
Python xlrd.xlwt.xlutils读取.修改Excel文件 一.xlrd读取excel 这里介绍一个不错的包xlrs,可以工作在任何平台.这也就意味着你可以在Linux下读取Excel文 ...
- 浅谈python之利用pandas和openpyxl读取excel数据
在自学到接口自动化测试时, 发现要从excel中读取测试用例的数据, 假如我的数据是这样的: 最好是每行数据对应着一条测试用例, 为方便取值, 我选择使用pandas库, 先安装 pip instal ...
- Python笔记-第一天
1.Python的输出print函数要把输出的字符串用单引号或者双引号括起来,但是不能混用. 比如print('hello,world')和print("hello,world") ...
- python笔记 - day3
python笔记 - day3 参考:http://www.cnblogs.com/wupeiqi/articles/5453708.html set特性: 1.无序 2.不重复 3.可嵌套 函数: ...
- python笔记之常用模块用法分析
python笔记之常用模块用法分析 内置模块(不用import就可以直接使用) 常用内置函数 help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像 ...
- python笔记之提取网页中的超链接
python笔记之提取网页中的超链接 对于提取网页中的超链接,先把网页内容读取出来,然后用beautifulsoup来解析是比较方便的.但是我发现一个问题,如果直接提取a标签的href,就会包含jav ...
- python笔记之ZipFile模块
python笔记之ZipFile模块 zipfile模块用来做zip格式编码的压缩和解压缩的,zipfile里有两个非常重要的class, 分别是ZipFile和ZipInfo, 在绝大多数的情况下, ...
随机推荐
- mpi转以太网连接300PLC与施耐德 Quantum PLC 通讯
S7300 PLC转以太网无需编程与施耐德 Quantum PLC modbusTCP通信 方案介绍: 西门子300PLC转以太网不需要编写程序通过兴达易控MPI-ETH-XD1.0与施耐德 Quan ...
- oracle多账套(用户)引用同一个账套的表或视图数据
1.赋权限访问nbjf账套权限给到其他账套用户. grant select on nbjf.receivables to gzjf,hfjf,hfjy; 2.分别登陆 gzjf,hfjf,hfjy账套 ...
- daffodil
import java.util.ArrayList; public class Daffodil { /** * 打印出100-999之间所有的"水仙花数",所谓"水仙 ...
- 面向生产的 LLM 优化
注意 : 本文同时也是 Transformers 的文档. 以 GPT3/4.Falcon 以及 LLama 为代表的大语言模型 (Large Language Model,LLM) 在处理以人为中心 ...
- Flex 布局项目实战,好像没那么难!
在上篇文章别再用 float 布局了,flex 才是未来!中,我们聊到 Flex 布局才是目前主流的布局方式.在文章最后,我们还贴了一个案例,并且还浅浅地讲解了一下. 有些小伙伴说,这讲解得太粗了,要 ...
- 浅析 C# Console 控制台为什么也会卡死
一:背景 1. 讲故事 在分析旅程中,总会有几例控制台的意外卡死导致的生产事故,有经验的朋友都知道,控制台卡死一般是动了 快速编辑窗口 的缘故,截图如下: 虽然知道缘由,但一直没有时间探究底层原理,市 ...
- unity UGUI 正交相机实现图片的透视旋转效果
UI透视效果常见的就是绕x轴或y轴旋转,来达到近大远小的效果.正经要做透视UI的话肯定直接用透视相机,如果透视效果用的极少(就一张图)不改动相机类型才按这种思路进行. 最简单直接的想法就是把矩形的图片 ...
- Windows 下修改MySQL的密码
修改密码的两种简单方法 今天需要修改MySQL的密码,记录一下. 第一种用SET PASSWORD命令 1.打开cmd进入MySQL的bin目录:(如我的路径是C:\Program Files\My ...
- 洛谷1451(BFS)
#include"bits/stdc++.h" using namespace std; int mp[110][110]; bool vis[110][110]; int dx[ ...
- 【爬虫实战】用Python采集任意小红书笔记下的评论,爬了10000多条,含二级评论!
目录 一.爬取目标 二.爬虫代码讲解 2.1 分析过程 2.2 爬虫代码 三.演示视频 一.爬取目标 您好!我是@马哥python说 ,一名10年程序猿. 我们继续分享Python爬虫的案例,今天爬取 ...