封装Excel工具类

我们常用的excel工具类,读有xlrd,写有xlwt。有读有写,新一代库有pandas,openpyxl等等。

大家用法都差不多,今天博主就介绍新手最爱,我也爱的xlrdxlwt。(不过xlwt似乎最多只支持65535条数据,此乃一坑)

缘起

老板给博主安排了一个导出excel的任务,而这个新项目里面还尚未编写此类公共方法,于是就想来一波尝试。

主要是想把xlwt和xlrd做一个整合,但并不是说要对一个文件读和写,因为应用场景一般是导入或者导出

封装ExcelHelper类

读数据

我们需要先接受一个filename(文件的全路径),初始化helper对象,所以我们可以顺手写出这样的代码:

class ExcelHelper(object):def __init__(self, filename):self.filename = filename

接着我们编写xlrd的部分,虽然网上的例子一大把,但是有特色的还是少。我决定支持读数组,也支持读json数组。

啥子是json数组,因为我们excel一般都是表头+表数据组成,如果光给一条数据,你不知道他属于哪一列,那还得往上找它的表头,和之对应起来。

比如我们经常读出的数据是:

data = [['姓名', '电话'],['三毛', '17800000000']
]

当列的数据比较多的时候,我们给你一个三毛,你知道它的表头是姓名吗?还是小名?

如果是这样的数据呢?

data = [{"姓名": "三毛", "电话": "17800000000"}
]

两种数据,不同的展示方式,其实内容相差无几。

  • 编写read_data方法
    def read_data(self):"""获取数据,不区分表头:return:"""book = xlrd.open_workbook(self.filename)sheets = book.sheets()for s in sheets:yield (s.row_values(i) for i in range(s.nrows))

这边用了yield关键字,之所以不用list,还是考虑到数据表数据如果很多,那么全部放到list,会占用很大内存空间,所以用了yield节省内存空间

这里如果有疑问,大家可以查下生成器相关资料。

  • 编写read_json相关方法
    @staticmethoddef read_json_item(sheet):"""获取json数据:param sheet::return:"""if sheet.nrows <= 1:return (sheet.row_values(i) for i in range(sheet.nrows))# 否则说明数据大于1行header = sheet.row_values(0)for i in range(1, sheet.nrows):row_data = dict()for j in range(sheet.ncols):row_data[header[j]] = sheet.cell_value(i, j)yield row_datadef read_json_data(self):"""获取List[dict]数据,也就是JSON数组:return:"""book = xlrd.open_workbook(self.filename)sheets = book.sheets()for st in sheets:yield ExcelHelper.read_json_item(st)

比较常规,excel可能会有多个sheet,所以我们遍历sheets。接着去每个sheet中拿到每行数据,由于要求json数组模式,所以我们需要判断下行数。

如果就1行,那就最多一个表头,没啥意义,所以我们直接切换到原生模式,一行一行读数据。

写数据

python编程https://edu.csdn.net/course/detail/36170

写数据的demo比较简单,考虑到传入json数组的时候,万一有小可爱传这样的数据,其实我们是不太好支持的:

a = [{"名字": "张三", "称号": "法外狂徒"},{"性格": "闷骚", "称号": "秒杀光环"}
]

可以看到2条数据对不上~所以不打算支持这样的数据。

  • 编写write_data方法

    我们知道,表头是个很重要的数据,我们要让她与众不同一点,所以我们可以设置下它的样式。

    @staticmethoddef get_style():style = xlwt.XFStyle()pattern = xlwt.Pattern()pattern.pattern = xlwt.Pattern.SOLID_PATTERNpattern.pattern_fore_colour = xlwt.Style.colour_map['sky_blue']style.pattern = patternreturn style

创建style,设置背景色为纯洁的天蓝色,最后返回style。

这个style有什么用呢,我们在写入数据的时候可以指定单元格的样式。

接着编写write方法:

    def write_excel_data(self, header, row_data, sheet_name="sheet1"):wb = xlwt.Workbook()ws = wb.add_sheet(sheet_name)# 写入表头for i, h in enumerate(header):ws.write(0, i, h, self.style)# 写入数据for line, row in enumerate(row_data):for c, item in enumerate(row):ws.write(line + 1, c, str(item))wb.save(self.filename)

接受参数是表头(数组),row_data(二维数组),写入完毕后调用save方法。

如果有需要对多个sheet写入,请自行改造。

本节总体来说,只是写了一个excel的读写方法,亮点在于读json数组表头搞颜色

下次聊聊FastApi下载文件以及删除下载后的文件。


完整代码如下(其实是给我自己备份):

import xlrd
import xlwtclass ExcelHelper(object):def __init__(self, filename):self.filename = filenameself.style = ExcelHelper.get_style()@staticmethoddef get_style():style = xlwt.XFStyle()pattern = xlwt.Pattern()pattern.pattern = xlwt.Pattern.SOLID_PATTERNpattern.pattern_fore_colour = xlwt.Style.colour_map['sky_blue']style.pattern = patternreturn styledef read_data(self):"""获取数据,不区分表头:return:"""book = xlrd.open_workbook(self.filename)sheets = book.sheets()for s in sheets:yield (s.row_values(i) for i in range(s.nrows))@staticmethoddef read_json_item(sheet):"""获取json数据:param sheet::return:"""if sheet.nrows <= 1:return (sheet.row_values(i) for i in range(sheet.nrows))# 否则说明数据大于1行header = sheet.row_values(0)for i in range(1, sheet.nrows):row_data = dict()for j in range(sheet.ncols):row_data[header[j]] = sheet.cell_value(i, j)yield row_datadef read_json_data(self):"""获取List[dict]数据,也就是JSON数组:return:"""book = xlrd.open_workbook(self.filename)sheets = book.sheets()for st in sheets:yield ExcelHelper.read_json_item(st)def write_excel_data(self, header, row_data, sheet_name="sheet1"):wb = xlwt.Workbook()ws = wb.add_sheet(sheet_name)# 写入表头for i, h in enumerate(header):ws.write(0, i, h, self.style)# 写入数据for line, row in enumerate(row_data):for c, item in enumerate(row):ws.write(line + 1, c, str(item))wb.save(self.filename)

python编程https://edu.csdn.net/course/detail/36170

Python Excel工具类封装, 实现excel表头加颜色相关推荐

  1. Python Excel工具类封装, 给excel表头搞点颜色

    封装Excel工具类 我们常用的excel工具类,读有xlrd,写有xlwt.有读有写,新一代库有pandas,openpyxl等等. 大家用法都差不多,今天博主就介绍新手最爱,我也爱的xlrd和xl ...

  2. easyPoi导出excel工具类和设置excel导出样式(边框,背景色,字体)

    如有疑问可加easypoi官方群,QQ群号码: 116844390 引入依赖,此样式基于springboot版本.依赖版本如下(maven):<dependency><groupId ...

  3. Java写一个excel工具类_Java中Excel写操作工具类--Java免费学习网

    核心提示:package com.common.excel;import com.common.excel.exception.WriteExcelException;import jxl.Workb ...

  4. java 兼容excel_Java解析Excel工具类(兼容xls和xlsx)

    依赖jar org.apache.poi poi-ooxml 4.0.1 ExcelUtils.java package javax.utils; import java.io.File; impor ...

  5. 【Apache POI】Excel操作(八):Excel工具类的封装(终极版)

    恋爱最珍贵的纪念品,从来就不是那些你送我的手表和项链,甚至也不是那些甜蜜的短信和合照.是你留在我身上的,如同河流留给山川的,那些你对我造成的改变. 有目录,不迷路 前言 代码开整 环境准备 正式开整 ...

  6. Java导入导出Excel工具类ExcelUtil

    前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出 本项目的持久化层用的是JPA(底层用hiberna ...

  7. Java解析Excel工具类(兼容xls和xlsx)

    依赖jar <dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml< ...

  8. 自定义POI的excel工具类-xls-xlsx

    自定义POI的excel工具类-xls-xlsx 使用jdk8(java8)实现Excel导出,随意切换 xls和xlsx.自己只是封装了比较常用方法,07版生成还有bug.ε=(´ο`*)))唉 j ...

  9. Java导入Excel工具类使用教程

    前言: 本工具类提供了Excel导入功能,通过反射机制将Excel中数据映射到实体类中,从而获取Excel数据,工具类依赖org.apache.poi包.支持RESTful API,支持Spring ...

最新文章

  1. MR21 VS MR22 对CKMLCP结果影响
  2. sql:CallableStatement执行存储过程
  3. BZOJ 1070: [SCOI2007]修车(最小费用最大流)
  4. HTML5 保存画布
  5. 豪情-2014年年终总结
  6. oracle只能在指定目录下访问,只安装PLSQL怎么访问远程数据库
  7. 算法系列15天速成——第五天 五大经典查找【中】
  8. Python:下载安装包
  9. powerdesigner制作数据字典
  10. C#贪吃蛇游戏(全代码)
  11. C语言变量inv,编写一个函数inv,将数组a中n个整数按相反顺序存放,用指针变量作为调用该函数时的实参...
  12. 小程序前端获取手机号码
  13. TwinCAT3库文件制作
  14. C语言基础:函数的声明与定义
  15. SRM 551 ColorfulCupcakesDivTwo
  16. 2019上海交大计算机考研群,2019年科班二战上海交大计算机专硕,调剂非全初复试经验教训分享!...
  17. selenium4+pyetsst+allure+pom进行自动化测试框架的最新设计
  18. 0门槛的数据可视化软件,帮你快速上手制作炫酷的可视化大屏
  19. C++实现二维快速傅里叶变换(FFT)
  20. MuseDash for mac中文破解版

热门文章

  1. ESXi 中重新启动管理代理
  2. 阿里云、腾讯云和华为云618活动细节对比
  3. centos 更改root用户名(超简单)
  4. Jquery学习总结(6)——JQuery万能代码段
  5. 我喜欢用计算机400字,我的电脑400字作文
  6. 小括号教学设计导入_如何在教学中凸显出学生的主体地位呢?原来只需要做到这几点即可...
  7. 页面中php传值后循环列表js获取点击的id
  8. 厦华电子:转型迎来新征程 打造大数据领军企业
  9. JdbcTemplate的主要用法
  10. Windows音频编程:Win32 Wave API 的使用