一、使用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表格的更多相关文章

  1. python 处理 Excel 表格

    see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...

  2. python 对Excel表格的写入

    python对Excel表格写入需要导入xlrd ,和xlutils两个库 from xlrd import open_workbook from xlutils.copy import copy o ...

  3. Python 利用Python操作excel表格之openyxl介绍Part2

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart()    ...

  4. Python 利用Python操作excel表格之openyxl介绍Part1

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...

  5. 【转】python操作excel表格(xlrd/xlwt)

    [转]python操作excel表格(xlrd/xlwt) 最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异, ...

  6. Python 利用Python操作excel表格之xlwt介绍

    利用Python操作excel表格之xlwt介绍   by:授客 QQ:1033553122 直接上代码   案例1 #!/usr/bin/env python # -*- coding:utf-8 ...

  7. Python读写Excel表格

    最近在做一些数据处理和计算的工作,因为数据是以.CSV格式保存的,因此刚开始直接用Excel来处理. 但是做着做着发现重复的劳动,其实并没有多大的意义,于是就想着写个小工具帮着处理. 以前正好在一本书 ...

  8. 通过Python将Excel表格信息导入数据库

    前言 公司原采用Excel表格方式记录着服务器资产信息,随着业务的增加,相应的硬件资产也增加,同时物理机虚拟化出多台虚拟机,存在表格管理杂乱.变更资产信息不能及时相互同步, 为了紧跟时代的步伐,老大搞 ...

  9. python - 操作excel表格

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  10. 使用Python处理Excel表格的简单方法

    使用Python处理Excel表格的简单方法 这篇文章主要介绍了使用Python处理Excel表格的简单方法,本文给大家介绍的非常详细,需要的朋友可以参考下 Excel 中的每一个单元,都会有这些属性 ...

随机推荐

  1. 实现简单Mybatis案例

    Mybatis源码结构 Mybatis核心三大阶段 Mybatis初始化: 初始化过程: Configuration 类 SqlSession对外提供接口 翻译过程: SqlSession查询接口嵌套 ...

  2. ANSYS 非线性材料模型简介1 ---常用弹塑性模型

    目录 1. 材料非线性 2. 三个准则 2.1 屈服准则 2.2 流动准则 2.3 强化准则 3. 常用弹塑性模型 3.1 双线性等向强化 3.2 多线性等向强化 3.3 非线性等向强化 3.4 双线 ...

  3. 【原】cookie和session的区别

    1.存放位置 cookie的数据存放在客户端的浏览器上,session存放在服务器上 2.安全程度 cookie不是很安全,别人通过分析本地的cookie并进行cookie欺骗:考虑到安全应该使用se ...

  4. Educational Codeforces Round 77 (Rated for Div. 2) - D. A Game with Traps(二分)

    题意:$m$个士兵,每个士兵都有一个灵敏度$a[i]$,起点为$0$,终点为$n + 1$,在路上有$k$个陷阱,每个陷阱有三个属性$l[i],r[i],d[i]$,$l[i]$表示陷阱的位置,如果你 ...

  5. Pandas的Categorical Data类型

    pandas从0.15版开始提供分类数据类型,用于表示统计学里有限且唯一性数据集,例如描述个人信息的性别一般就男和女两个数据常用'm'和'f'来描述,有时也能对应编码映射为0和1.血型A.B.O和AB ...

  6. 【SSM - druid 】配置与使用

    web.xml 配置 <!-- druid的监控页面配置开始 --> <servlet> <servlet-name>StatViewServlet</ser ...

  7. floyd的魔改应用——洛谷P2419 [USACO08JAN]牛大赛Cow Contest 题解

    想找原题请点击这里:传送门 原题: 题目背景 [Usaco2008 Jan] 题目描述 N ( ≤ N ≤ ) cows, conveniently numbered ..N, are partici ...

  8. 编译安装nginx错误解决!

    编译安装执行 ./configure --prefix=/root/web/nginx --sbin-path=/root/web/nginx/sbin/nginx --conf-path=/root ...

  9. Oracle字符集查询及修改

    字符集包括以下四种: 1.oracle服务端字符集 select * from nls_database_parameters; 2.oracle服务器注册字符集 HKEY_LOCAL_MACHINE ...

  10. Servlet返回的数据js解析问题

    Servlet返回的数据js解析问题 方式1:Json 接收函数:ajax.responseText后面没括号 其实在之前所说的ajax中还遗留了一些问题就是,Servlet返回给js的数据是如何被j ...