最近工作时碰到了将数据导出,生成一个excel表,对其中的部分数据进行统计,并给其中部分符合条件的数据添加对应的背景颜色的功能需求,于是乎,对Python中写excel的模块xlwt研究了一下,在工作过程中发现,想要实现数据统计的话,xlwt并没有直接的公式,而是给了一个把内容以公式的格式写入excel的方法,所以又对excel的公式什么的研究了一下,也算是终于实现了想要的功能,现把觉得用处比较大的记录一下,以便以后用到的时候可以直接捡起来用。

xlwt的安装

很简单,可以直接使用pip安装

  1. pip install xlwt

xlwt的导入

很简单,直接import即可

  1. import xlwt

最简单的例子(xltw使用的坐标和excel表的坐标不同,excel有两种坐标表示方式,但都是从1开始,例如左上角第一个单元格为A1(字母为横坐标,数字为纵坐标)或者R1C1(R1表示纵坐标,C1表示横坐标),而xlwt模块中,坐标的数字则是从0开始左上角第一个单元格的坐标为(0,0),其中的一个数字为纵坐标,第二个数字为横坐标)

  1. import xlwt
    xls = xlwt.Workbook(encoding="utf-8") # 创建一个xls对象,用来保存对excel表的操作
  2. sheet1 = xls.add_sheet('成绩表', cell_overwrite_ok=True) # 给 xls 添加一张‘成绩表’的表格
  3. sheet1.write(0, 0, '学生姓名') # 在坐标为0,0的单元格内添加内容'学生姓名'
  4. sheet1.write(0, 1, '成绩') # 在坐标为1,1的单元格内添加内容'成绩'  
  5. sheet1.write(0, 2, '评语') # 在坐标为0,2的单元格内添加内容'评语'
  6. xls.save('测试表') # 将xls保存为'测试表'

即可生成如下图如所示的excel表

设置字体属性

  1. import xlwt
  2. workbook = xlwt.Workbook(encoding = 'utf-8')
  3. worksheet = workbook.add_sheet('测试表')
  4. font = xlwt.Font() # 创建一个font对象,用来保存对字体进行的操作
  5. font.name = '微软雅黑' # 将字体设置为'微软雅黑'
  6. font.bold = True # 设置字体加粗
  7. font.underline = True # 设置字体加下划线
  8. font.italic = True # 设置字体倾斜
  9. style = xlwt.XFStyle() # 创建一个style对象,用来保存excel的样式
  10. style.font = font # 将字体信息保存到style对象中
  11. worksheet.write(0, 0, '无字体格式')
  12. worksheet.write(1, 0, '有字体格式', style) # 在坐标为1,0的单元格内添加内容'有字体格式',并带有字体属性
  13. workbook.save('测试表.xlsx')

生成如下图如所示的excel表

设置背景图案

  1. import xlwt
  2. workbook = xlwt.Workbook()
  3. worksheet = workbook.add_sheet('测试表')
  4. pattern = xlwt.Pattern() # 创建一个pattern对象,用来保存单元格背景的样式
  5. pattern.pattern = 0x01 # 设置单元格的背景图案样式(0x01-0x12共18种样式)
  6. pattern.pattern_fore_colour = xlwt.Style.colour_map['yellow'] # 设置单元格的背景颜色
  7. style = xlwt.XFStyle()
  8. style.pattern = pattern # 将背景颜色信息保存到styke对象中
  9. worksheet.write(0, 0, '有背景颜色', style) # 在坐标为0,0的单元格内添加内容'有背景',并带有背景颜色
  10. workbook.save('测试表.xlsx')

生成如下图如所示的excel表

合并单元格

  1. import xlwt
  2. workbook = xlwt.Workbook()
  3. worksheet = workbook.add_sheet('测试表')
  4. worksheet.write_merge(0, 0, 0, 1, '合并两列') # 将坐标为0,0和0,1的两列合并,并添加内容'合并两列'
  5. worksheet.write_merge(1, 2, 0, 0, '合并两行') # 将坐标为1,0和2,0的两行合并,并添加内容'合并两行'
  6. worksheet.write_merge(3, 5, 0, 2, '合并三行三列') # 将纵坐标为3-5横坐标为0-2的三行三列合并,并添加内容'合并三行三列'
  7. workbook.save('测试表.xlsx')

生成如下图如所示的excel表

设置单元格的列宽(xlwt中没有专门的设置行高的方法,可通过设置单元格的字号调整行高)(xlwt中列宽的单位为默认字体(10号字)的0的宽度的1/256)

  1. import xlwt
  2. book = xlwt.Workbook(encoding='utf-8')
  3. sheet = book.add_sheet('测试表')
  4. first_col=sheet.col(0) # 获得测试表中横坐标为0的列
  5. first_col.width=256*20 # 将或的的列的宽设置为256*20个单位,即20个10号字的0的宽度
  6. book.save('测试表.xlsx')

生成如下图如所示的excel表

在单元格内插入公式

  1. import xlwt
  2. workbook = xlwt.Workbook()
  3. worksheet = workbook.add_sheet('测试表')
  4. worksheet.write(0, 0, 1)
  5. worksheet.write(0, 1, 2)
  6. worksheet.write(0, 2, xlwt.Formula('A1*B1')) # 在坐标为0,2的单元格单元格内添加一个公式,公式内容为‘=A1*B1’,显示的值为A1与B1两单元格的值得积:2
  7. worksheet.write(0, 3, xlwt.Formula('SUM(A1,B1)')) # 在坐标为0,3的单元格单元格内添加一个公式,公式内容为‘=SUM(A1,B1)’,显示的值为A1与B1两单元格的值得和:3
  8. workbook.save('测试表.xlsx')

生成如下图如所示的excel表

另附部分excel公式(好吧,我承认是我在工作中用到的)

统计数量(COUNTIF(区域,条件))

例子1:统计1出现的次数

例子2:统计不是1的值出现的次数

乘积之和(SUMPRODUCT(数组1,数组2, ··· ···)):

例子:计算数组1和数组2的对应位置的数的乘积的和

条件求和(SUMIF(条件区域,判断条件,运算区域)(若省略运算区域,则条件区域即是运算区域))

例子:在A1-A6范围内值为1的单元格,在B1-B6范围内对应的单元格的值的和

多条件求和(SUMIFS(运算区域,条件区域1,判断条件1,条件区域2,判断条件2,··· ···))

例子:在A1-A6范围内值为1,在B1-B6范围内值为1的单元格,在C1-C6范围内对应的单元格的值的和

xlwt:python的写excel模块的更多相关文章

  1. python 写 excel 模块 : xlwt

    主要来自:[ python中使用xlrd.xlwt操作excel表格详解 ] 为了方便阅读, 我将原文两个模块拆分为两篇博文: [ python 读 excel 模块: xlrd ] [ python ...

  2. Python读写操作Excel模块_xlrd_xlwt_xlutils

    Python 读写操作Excel -- 安装第三方库(xlrd.xlwt.xlutils.openpyxl) 如果仅仅是要以表单形式保存数据,可以借助 CSV 格式(一种以逗号分隔的表格数据格式)进行 ...

  3. python xlsxwriter写excel并操作各种格式属性

    # -*- coding: utf-8 -*- import xlsxwriter workbook = xlsxwriter.Workbook('test.xlsx') worksheet = wo ...

  4. Python xlwt 写Excel相关操作记录

    1.安装xlwt pip install xlwt 2.写Excel必要的几步 import xlwt book = xlwt.Workbook() #创建一个workbook,无编码设置编码book ...

  5. python 读 excel 模块: xlrd

    主要来自:[ python中使用xlrd.xlwt操作excel表格详解 ] 为了方便阅读, 我将原文两个模块拆分为两篇博文: [ python 读 excel 模块: xlrd ] [ python ...

  6. python 3 操作 excel

    看到一篇很好的python读写excel方式的对比文章: 用Python读写Excel文件 关于其他版本的excel,可以通过他提供的链接教程进行学习. XlsxWriter: https://git ...

  7. Python xlwt模块写Excel问题集合

    1.数字转换成汉字 数据库查询返回结果为多元组,在写入Excel需要判断,数据库查询结果是否为数字,为数字的话需要将其转换成对应的汉字,此时元组不可修改,所以需要将返回结果修改成列表.实现可以在数据库 ...

  8. python中使用xlrd读excel使用xlwt写excel

    原文地址 :http://www.bugingcode.com/blog/python_xlrd_read_excel_xlwt_write_excel.html 在数据分析和运营的过程中,有非常多的 ...

  9. 使用Python xlwt写excel文件

    如果需要使用Python写Excel文件,首先下载或者安装xlwt. pip install xlwt 下面的这些demo应该可以帮助开发者快速上手使用xlwt写Excel文件: 创建工作簿(work ...

随机推荐

  1. Spring源码之事务(一)— TransactionAutoConfiguration自动配置

    总结: 在ConfigurationClassParser#parse()中会对deferredImportSelectorHandler进行处理(在处理@ComponentScan 自己所写@Com ...

  2. ceph 的crush算法 straw

    很多年以前,Sage 在写CRUSH的原始算法的时候,写了不同的Bucket类型,可以选择不同的伪随机选择算法,大部分的模型是基于RJ Honicky写的RUSH algorithms 这个算法,这个 ...

  3. ubuntu服务器dns重启失效问题

    方法一 通过/etc/network/interfaces,在它的最后增加一句: dns-nameservers 8.8.8.8 8.8.8.8是Google提供的DNS服务,这里只是举一个例子,你也 ...

  4. Python_字符串_方法

    #字典#把字符串中的字母提取出来改为大写并计数 a="aAsmr3idd4bgs7Dlsf9eAF" b1=[x for x in a if x.isalpha()] b=''.j ...

  5. Cisco思科模拟器路由器各个端口IP地址的配置及路由协议RIP的配置 入门详解 - 精简归纳

    Cisco思科模拟器路由器各个端口IP地址的配置及路由协议RIP的配置 入门详解 - 精简归纳 JERRY_Z. ~ 2020 / 11 / 21 转载请注明出处!️ 附: 交流方式: ️ ️ ️ Q ...

  6. kafka SASL认证介绍及自定义SASL PLAIN认证功能

    目录 kafka 2.x用户认证方式小结 SASL/PLAIN实例(配置及客户端) broker配置 客户端配置 自定义SASL/PLAIN认证(二次开发) kafka2新的callback接口介绍 ...

  7. Vegas的软对比具体如何设置

    软对比是Vegas中比较常用的一个视频特效,通过这一特效可以让视频画面更加柔和.而对于新手用户来说,软对比显得有些陌生,不知道该如何使用. 本集主要为大家介绍:sony vegas的软对比. 在视频制 ...

  8. jQuery 第五章 实例方法 事件

    .on() .one() .off() .trigger() .click / keydown / mouseenter ...    .hover() ----------------------- ...

  9. Nacos安装与启动教程

    前言 Nacos是阿里巴巴集团开源的一个易于使用的平台,专为动态服务发现,配置和服务管理而设计,Nacos基本上支持现在所有类型的服务,例如,Dubbo / gRPC服务,Spring Cloud R ...

  10. Java命令行启动jar包更改默认端口以及配置文件的几种方式

    Java命令行启动jar包更改默认端口以及配置文件的几种方式 java -jar xxx.jar --server.port=8081 默认如果jar包没有启动文件,可以采用这种方式进行启动 java ...