本次是在原来有一定格式的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,实现班级成绩的统计的更多相关文章

  1. python学习笔记(八)python操作Excel

    一.python操作excel,python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的 ...

  2. 用Python操作excel文档

    使用Python第三方库 这一节我们学习如何使用Python去操作Excel文档.如果大家有人不知道Excel的话,那么建议先学一学office办公基础.这里想要操作Excel,必须安装一个Pytho ...

  3. python操作excel表格(xlrd/xlwt)

    最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而且不太能满足需求,不过经过一番对源码的"研究&q ...

  4. Python操作Excel

    一.系统性学习 对于操作Excel,需要Xlrd/xlwt这两个模块,下面推荐出系统性学习的网址: python操作Excel读写--使用xlrd 官方文档 Python 使用 Xlrd/xlwt 操 ...

  5. Python操作excel(xlrd和xlwt)

    Python操作excel表格有很多支持的库,例如:xlrd.xlwt.openpyxl.win32com,下面介绍使用xlrd.xlwt和xlutils模块这三个库不需要其他的支持,在任何操作系统上 ...

  6. Python操作excel表格

    用Python操作Excel在工作中还是挺常用的,因为毕竟不懂Excel是一个用户庞大的数据管理软件 注:本篇代码在Python3环境下运行 首先导入两个模块xlrd和xlwt,xlrd用来读取Exc ...

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

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

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

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

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

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

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

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

随机推荐

  1. Mysql导入Excel数据 日期问题 (Excel 与 MySQL 时间戳格式和日期 互转)

    https://blog.csdn.net/ghw455954461/article/details/7247738 今天项目表中需要导入好几w条数据 ,但日期由两个一个是标准时间一个为时间戳,程序中 ...

  2. Vue入门(一)——环境搭建

    1.参考该教程装vue脚手架和创建工程 https://segmentfault.com/a/1190000008922234 附:在每个工程下cmd,执行npm install,此时工程下会多一个n ...

  3. JavaScript 基础知识梳理——数据类型

    JavaScript的数据类型公有六种,ES6又新增了第七种Symbol类型的值. 数值(number) 字符串(string) 布尔值(boolean) undefined null 对象(obje ...

  4. 移动端性能监控方案Hertz

    移动端性能监控方案Hertz 吴凯 瑞利 富强 徐宏 ·2016-12-19 16:10 性能问题是造成App用户流失的罪魁祸首之一.App的性能问题包括崩溃.网络请求错误或超时.响应速度慢.列表滚动 ...

  5. wmware虚拟化的启动问题

    2019-05-09,14点14 vmware出现VMware提示:已将该虚拟机配置为使用 64 位客户机操作系统.但是,无法执行 64 位操作.解决方案 进入bios里面intel 虚拟化技术 先设 ...

  6. 在laravel5.8中集成swoole组件----初步测试

    铺垫 前提是先安装swoole组件,我采用从pecl-----php扩展组件网下载swoole扩展包,然后切入到解压缩的扩展包中运行phpize命令, phpize是一种编译命令,可以在安装文件中生成 ...

  7. RabbitMQ与Spring集成配置

    1.引入相关jar包 //RabbitMQ compile group: 'org.springframework.amqp', name: 'spring-rabbit', version: '1. ...

  8. kafka什么时候会丢消息(转)

    因为在具体开发中某些环节考虑使用kafka却担心有消息丢失的风险,本周结合项目对kafka的消息可靠性做了一下调研和总结: 首先明确一下丢消息的定义.kafka集群中的部分或全部broker挂了,导致 ...

  9. Redis:RedisHelper(5)

    /// <summary> /// Redis 助手 /// </summary> public class RedisHelper { /// <summary> ...

  10. uint128_t 添加 c++ 重载类型强制转换

    类型声明: class uint128 { public: uint128() :hi(), lo(){} uint128(uint32_t l) :hi(), lo(l){} uint128(int ...