用Python操作Excel,实现班级成绩的统计
本次是在原来有一定格式的Excel文档中补充成绩。
- 安装的模块:xlwt 、 xlrd 、xlutils
xlrd的模块是只用读取xls文件,不能写文件,同理xlwt,只(新建写)不读已有的xls,
xlrd的用法:
- 打开文件:
data =xlrd.open_workbook(fime_path+'011.xls') - 读取sheet:
table = data.sheet_by_index(0) - 获取行数和列数:
nrows = table.nrows
ncols = table.ncols
- 读取单元格:
table.cell(i,j).value
xlwt的用法
- 初始化workbook对象:
wbk = xlwt.Workbook() - 表单创建:
sheet = wbk.add_sheet('sheet 1') - 写单元:
sheet.write(0,1,'test text') - 保存:
wbk.save('test.xls')
到了讲怎么在原有的xls文档追加。这就使用到xlutils,xlutils(依赖于xlrd和xlwt)提供复制excel文件内容和修改文件的功能。其实际也只是在xlrd.Book和xlwt.Workbook之间建立了一个管道而已,如下图:

- 导包:
from xlutils.copy import copy - 先用xlrd打开文件:
old_xls = xlrd.open_workbook(file_path2,formatting_info=True) - 然后复制,使其转化成xlwt对象:
table_xlwt_b = copy(old_xls) - 获取已有表单:
table_xlwt = table_xlwt_b.get_sheet(0) - 修改单元格值:
table_xlwt.write(id_p,j,list[k]) #iid_p是行,j是列,list[k]是填充的值 - 保存:
table_xlwt_b.save(fime_path+"033.xls")
最后需要注意,打开原有xls文件,需要保留文档单元格的格式,需要在xlrd打开文件参数添加formatting_info=True,(默认是FALSE),同时,这参数只支持旧版的xls后缀的文件,不支持新版的xlsx后缀的文档,,如果打开xlsx会抛出异常,因此需要另存为xls文档
最后附上代码
#!coding:utf-8
import xlrd
import xlwt
import copy
from xlutils.copy import copy
fime_path="F:\\program_new\\PyCharm Community Edition 2018.2.3\\code_example\\xlwt_xlrd\\code\\"
old_xls = xlrd.open_workbook(fime_path+"022.xls", formatting_info=True)
def read_book():
data =xlrd.open_workbook(fime_path+'011.xls')
#导入表
table = data.sheet_by_index(0)
nrows = table.nrows
ncols = table.ncols
i=0
j=0
list_score = []
score = []
for i in range(1,nrows):
for j in range(6,ncols):
# print("%d%d"%(i,j))
score.append(table.cell(i,j).value)
list_score.append(score)
score=[]
return list_score
def id_position(student_id):
tabel_xlwt_ot = old_xls.sheet_by_index(0)
nrows = tabel_xlwt_ot.nrows
ncols = tabel_xlwt_ot.ncols
for i in range(3,nrows):
now_student_id = int(tabel_xlwt_ot.cell(i,0).value)
now_student_id=str(now_student_id)
if now_student_id==student_id:
return i
def write_book():
table_xlwt_b = copy(old_xls)
table_xlwt = table_xlwt_b.get_sheet(0)
list2=read_book()
print(len(list2),len(list2[1]))
for list in list2:
s_id=list[0]
print(list)
id_p = id_position(s_id)
if id_p is not None:
for (j,k) in zip(range(2,27,3),range(2,11)):
print(k,j)
table_xlwt.write(id_p,j,list[k])
else:
print(u"找不到该学号%s"%s_id)
table_xlwt_b.save(fime_path+"033.xls")
if __name__=="__main__":
write_book()
不用关闭文件,官方没有提供具体的方法关闭打开的xls文件。可以使用
book.release_resources()释放内存

用Python操作Excel,实现班级成绩的统计的更多相关文章
- python学习笔记(八)python操作Excel
一.python操作excel,python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的 ...
- 用Python操作excel文档
使用Python第三方库 这一节我们学习如何使用Python去操作Excel文档.如果大家有人不知道Excel的话,那么建议先学一学office办公基础.这里想要操作Excel,必须安装一个Pytho ...
- python操作excel表格(xlrd/xlwt)
最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而且不太能满足需求,不过经过一番对源码的"研究&q ...
- Python操作Excel
一.系统性学习 对于操作Excel,需要Xlrd/xlwt这两个模块,下面推荐出系统性学习的网址: python操作Excel读写--使用xlrd 官方文档 Python 使用 Xlrd/xlwt 操 ...
- Python操作excel(xlrd和xlwt)
Python操作excel表格有很多支持的库,例如:xlrd.xlwt.openpyxl.win32com,下面介绍使用xlrd.xlwt和xlutils模块这三个库不需要其他的支持,在任何操作系统上 ...
- Python操作excel表格
用Python操作Excel在工作中还是挺常用的,因为毕竟不懂Excel是一个用户庞大的数据管理软件 注:本篇代码在Python3环境下运行 首先导入两个模块xlrd和xlwt,xlrd用来读取Exc ...
- 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 ...
随机推荐
- 2.PAT 1001 害死人不偿命的(3 n + 1 )猜想
题目: 卡拉兹(Callatz)猜想: 对任何一个正整数 n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把 ( 砍掉一半.这样一直反复砍下去,最后一定在某一步得到 n=1.卡拉兹在 1950 ...
- FFmpeg常用命令学习笔记(二)录制命令
录制命令 1.FFmpeg录屏命令 ffmpeg -f avfoundation -i 1 -r 30 out.yuv -f:指定使用avfoundation采集数据 -i:指定从哪采集数据,它是一个 ...
- GPU driven pipeline in metal
https://developer.apple.com/documentation/metal/dynamic_terrain_with_argument_buffers?language=objc ...
- yarn是什么?
yarn是个包管理器.你可以通过它使用全世界开发者的代码, 或者分享自己的代码. 从 npm 安装软件包并保持相同的包管理流程. 优点: 1.速度超快. Yarn 缓存了每个下载过的包 ...
- Mac中iterm2显示彩色
Mac中iterm2显示彩色 2016年08月23日 18:09:37 Sun7_She 阅读数:1974 参考网址:https://segmentfault.com/q/101000000065 ...
- 《30天自制操作系统》学习笔记--Mac环境搭建
弄了三天了,终于弄好了,先说结果,就是作者在网站上放了os x的工具(hrb.osask.jp,也有linux下的工具,可以自己去下载),也就是说我白忙活了三天... 再说一下这几天都干啥了,主要是想 ...
- Pycharm下将py文件打包成exe文件
1. 在PyCharm下安装PyInstaller 1. 首先,打开自己要发布的工程 2. 点击底部的[Terminal]打开终端,中输入命令pip install pyinstaller后回车, ...
- Selenium Firefox 官方Webdriver -- Geckodriver
下载地址: https://github.com/mozilla/geckodriver/releases 配置环境: 直接将解压的geckodriver.exe放到python的Scripts中 比 ...
- ARTS打卡计划第十三周
Algorithms: https://leetcode-cn.com/problems/longest-continuous-increasing-subsequence/ 最长连续子序列. Rev ...
- vuejs2项目开发实战视频教程
0.课程大纲 一.点餐系统(移动) 1.0.课件 1.1.项目初始化_首页顶部 1.2.首页列表_底部导航 1.3.商家顶部_商家优惠信息弹层 1.4.商品主体_类别菜单 1.5.购物车操作_商品信息 ...