Python—处理Excel表格
一、使用xlrd和xlwt这两个库来处理excel,即xlrd是读excel的库,xlwt是写excel的库
1.使用 xlrd 读取Excel数据
# -*- coding:utf-8 -*-
import xlrd def read_excel():
book = xlrd.open_workbook(filename='D:\Excel3.xls') # 打开文件
print(book.sheet_names()) # 获取所有表格名字 # 获取表格的方式
sheet1 = book.sheets()[0]
sheet2 = book.sheet_by_index(0) # 根据顺序获取sheet,0表示第一个sheet
sheet3 = book.sheet_by_name('学生1') # 根据sheet页名字获取sheet
print(sheet1.name, sheet1.nrows, sheet1.ncols) # 获取excel里面有多少行,多少列 sheet1.row_values(1) # 取第几行的数据,返回一个列表list
sheet1.col_values(1) # 取第几列的数据,返回一个列表list # 获取表格里的内容,三种方式:指定行和列获取数据,0行0列代表excel中第一个数据
print(sheet1.cell(1, 1).value)
print(sheet1.cell_value(1, 1))
print(sheet1.row(1)[1].value) excelhead = []
for i in range(sheet1.ncols): # 查询表头,即获取第一行的数据
excel_head_values = sheet1.col_values(i)
excelhead.append(excel_head_values[0])
print(excelhead) for i in range(sheet1.nrows)[1:]: # 查询行的值,从第二行开始
row_values = sheet1.row_values(i)
print(' '.join([str(x) for x in row_values])) if __name__ == "__main__":
read_excel()
2.使用 xlwt 写入Excel数据
- write(x, y, string):x表示行,y表示列,string表示要写入的单元格内容。
write_merge(x, x + m, y, w + n, string, sytle):x表示行,y表示列,m表示跨行个数,n表示跨列个数,string表示要写入的单元格内容,style表示单元格样式。其中,x,y,w,h,都是以0开始计算的。
- 示例:sheet1.write_merge(21,21,0,1,u'合计',set_style('Times New Roman',220,True)):即在22行合并第1,2列,合并后的单元格内容为"合计",并设置了style。
# -*- coding:utf-8 -*-
import xlwt def write_excel():
book = xlwt.Workbook() # 新建一个excel sheet1 = book.add_sheet('学生1') # 添加一个sheet页,创建第一个sheet:学生1
data = [['姓名', '年龄', '性别', '分数'], ['mary', 20, '女', 90], ['jack', 26, '男', 96]]
raw = 0 # 控制行
for stu in data: # 循环写入
col = 0 # 控制列
for s in stu:
sheet1.write(raw, col, s)
col += 1
raw += 1
sheet1.write_merge(3, 3, 1, 3, '待确认') # 合并列单元格,第2列到第4列合并
sheet1.write_merge(1, 3, 4, 4, '打游戏') # 合并行单元格,第2行到第4行合并 sheet2 = book.add_sheet('学生2', cell_overwrite_ok=True) # 添加一个sheet页,创建第二个sheet:学生2
row0 = ["姓名", "年龄", "爱好", "出生日期"]
col0 = ["张三", "李四", "小明", "小红", "无名"]
for i in range(0, len(row0)): # 写第一行
sheet2.write(0, i, row0[i])
for i in range(0, len(col0)): # 写第一列
sheet2.write(i + 1, 0, col0[i])
sheet2.write(1, 3, '91/12/12')
sheet2.write_merge(5, 5, 2, 3, u'暂无') # 合并列单元格
sheet2.write_merge(2, 3, 3, 3, u'94/05/06') # 合并行单元格 book.save('D:\Excel3.xls') # 保存文件 if __name__ == "__main__":
write_excel()
3.使用 xlutils 修改Excel数据
# -*- coding:utf-8 -*-
import xlrd
from xlutils.copy import copy book1 = xlrd.open_workbook('D:\Excel.xls') # 打开要修改的excel
book2 = copy(book1) # 拷贝一份原来的excel
sheet = book2.get_sheet(0) # 获取第几个sheet页
sheet.write(1, 1, 28) # 写入需要修改的行、列及修改后的值
sheet.write(5, 0, 'mike')
book2.save('D:\Excel.xls')
参考:https://blog.csdn.net/csdnnews/article/details/80878945
参考:https://www.jb51.net/article/60510.htm
二、使用 openpyxl 来处理excel
参考:https://www.jianshu.com/p/45c507e73172
参考:https://segmentfault.com/a/1190000016256490
参考:https://www.cnblogs.com/feifeifeisir/p/10419262.html
之后在研究
Python—处理Excel表格的更多相关文章
- python 处理 Excel 表格
see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...
- python 对Excel表格的写入
python对Excel表格写入需要导入xlrd ,和xlutils两个库 from xlrd import open_workbook from xlutils.copy import copy o ...
- Python 利用Python操作excel表格之openyxl介绍Part2
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart() ...
- Python 利用Python操作excel表格之openyxl介绍Part1
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...
- 【转】python操作excel表格(xlrd/xlwt)
[转]python操作excel表格(xlrd/xlwt) 最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异, ...
- Python 利用Python操作excel表格之xlwt介绍
利用Python操作excel表格之xlwt介绍 by:授客 QQ:1033553122 直接上代码 案例1 #!/usr/bin/env python # -*- coding:utf-8 ...
- Python读写Excel表格
最近在做一些数据处理和计算的工作,因为数据是以.CSV格式保存的,因此刚开始直接用Excel来处理. 但是做着做着发现重复的劳动,其实并没有多大的意义,于是就想着写个小工具帮着处理. 以前正好在一本书 ...
- 通过Python将Excel表格信息导入数据库
前言 公司原采用Excel表格方式记录着服务器资产信息,随着业务的增加,相应的硬件资产也增加,同时物理机虚拟化出多台虚拟机,存在表格管理杂乱.变更资产信息不能及时相互同步, 为了紧跟时代的步伐,老大搞 ...
- python - 操作excel表格
说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...
- 使用Python处理Excel表格的简单方法
使用Python处理Excel表格的简单方法 这篇文章主要介绍了使用Python处理Excel表格的简单方法,本文给大家介绍的非常详细,需要的朋友可以参考下 Excel 中的每一个单元,都会有这些属性 ...
随机推荐
- servlet类常用代码
1.设置响应编码格式 response.setContentType(");
- Spring学习(九)
JdbcTemplate需要的jar包 1.Spring核心必须依赖的库:commons-logging-1.1.1.jar2.Spring IoC部分核心库: spring-beans-4.3.9. ...
- 树莓派4B踩坑指南 - (8)安装GO语言
下载 191129最新版本为go1.13.4.linux-armv6l.tar.gz go官网(点此访问)国内访问似乎不是很稳定,但下载速度还挺快,下载地址:(点此访问) 安装 解压后是一个名为go的 ...
- 第二十九节: Asp.Net Core零散获取总结(不断补充)
1. IWebHostEnvironment获取常用属性 (1).获取项目的根目录 _env.ContentRootPath 等价于 Directory.GetCurrentDirectory() ( ...
- BigOps自动化运维安装以及所遇故障处理
本文参考官方文档进行安装,以及在安装中所遇到的问题呈现给大家.废话就不说了,开始安装.一.准备工作:本机系统环境是CentOS 7 x86 64位硬件配置建议物理内存8G+.CPU 4 cores+. ...
- 笔记-twisted源码-import reactor解析
笔记-twisted源码-import reactor解析 1. twisted源码解析-1 twisted reactor实现原理: 第一步: from twisted.internet ...
- IVM sdk command
1.load sdk shell ./auto_load_user.sh 2.查看all端口状态 IVM:0>ifcs show devport 3.查看个别端口状态 IVM:0>ifcs ...
- MySQL : INSERT INTO SELECT
INSERT INTO wx_announcement_push ( title, content, STATUS, del_flag, user_login_name ) SELECT '大家好', ...
- 《容器化.NET应用架构指南》脑图学习笔记(第一部分)
一.关于这本官方“圣经” 作为.NET程序员,对于微软官方推动的架构示例总是特别关注,从PetShop到MusicStore再到eShopOnContainers,每一次关注,都会了解到业界最新的架构 ...
- DRF项目之序列化器和视图重写方法的区别
我们,都知道,DRF框架是一款高度封装的框架. 我们可以通过重写一些方法来实现自定义的功能. 今天,就来说说在视图中重写和序列化器中重写方法的区别. 在视图中重写方法: 接收请求,处理数据(业务逻辑) ...