python xlsxwriter库生成图表的应用示例
作者:北京流浪儿 发布时间:2022-03-02 20:01:33
标签:python,图表
xlsxwriter可能用过的人并不是很多,不过使用后就会感觉,他的功能让你叹服,除了可以按要求生成你所需要的excel外
还可以加上很形象的各种图,比如柱状图、饼图、折线图等。
xlsxwriter 基本用法,创建 xlsx 文件并添加数据
官方文档:http://xlsxwriter.readthedocs.org/
xlsxwriter 可以操作 xls 格式文件
注意:xlsxwriter 只能创建新文件,不可以修改原有文件。如果创建新文件时与原有文件同名,则会覆盖原有文件
Linux 下安装: sudo pip install XlsxWriter
Windows 下安装: pip install XlsxWriter
请看本人生成的:
这里包含了数据公式的计算,插入图片的连接,生成的图表,当然如果你还需要其他的功能,可以继续参考库的文档
下面把源代码贴出来,希望对大家在工作遇到类似的情况,可以直接拿去用。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author:Eric.yue
import xlsxwriter
import random
from datetime import date
import collections
def xlwt_chart(xl_obj,table):
#生成柱状图
column_chart = xl_obj.add_chart({'type':'column'})
column_chart.add_series({
'name':'=sheet1!$D$1',
'categories':'=sheet1!$D$2:$D$7',
'values':'=sheet1!$E$2:$E$7'
})
table.insert_chart('G2',column_chart)
#生成饼图
column_chart2 = xl_obj.add_chart({'type':'pie'})
column_chart2.add_series({
'name': '=sheet1!$D$1',
'categories':'=sheet1!$D$2:$D$7',
'values': '=sheet1!$E$2:$E$7'
})
table.insert_chart('G20', column_chart2)
def xlwt_run():
data_base = ['0-50','50-60','60-70','70-80','80-90','90-100']
#生成一个有序的字典
chart_dict = collections.OrderedDict.fromkeys(data_base,0)
xl_obj = xlsxwriter.Workbook('chart.xlsx')
table = xl_obj.add_worksheet('sheet1')
table.write_string(0,0,u'姓名')
table.write_string(0,1,u'成绩')
table.write_string(0,2,u'日期')
table.merge_range('D1:E1', u'成绩分布')
table.set_column('C:E',15)
#定义格式
date_format = xl_obj.add_format({'num_format':'yyyy-mm-dd'})
color_format = xl_obj.add_format({'color':'red'})
font_format = xl_obj.add_format({'font_color':'green','bold':True})
mm = 1
for i in xrange(1,40):
name = 'name_%d' % i
score = random.randint(30,100)
if score <= 50:
chart_dict['0-50'] += 1
elif score>50 and score<=60:
chart_dict['50-60'] += 1
elif score>60 and score<=70:
chart_dict['60-70'] += 1
elif score>70 and score<=80:
chart_dict['70-80'] += 1
elif score>80 and score<=90:
chart_dict['80-90'] += 1
else:
chart_dict['90-100'] += 1
if score > 60:
table.write_string(i, 0, name)
table.write_number(i, 1, score)
else:
table.write_string(i, 0, name, color_format)
table.write_number(i, 1, score, color_format)
table.write_datetime(i, 2,date.today(), date_format)
mm = mm + 1
#生成图表数据
row = 1
for k,v in chart_dict.items():
table.write_string(row, 3, k, font_format)
table.write_number(row, 4, v, font_format)
row = row+1
xlwt_chart(xl_obj,table)
#使用公式
table.write_formula(mm,1,'=AVERAGE(B2:B40)')
#插入带链接的图片
table.insert_image('D20',r'/home/mywork/pythonchina/cto51_log/bd_logo12.png',{'url':'https://www.baidu.com'})
#关闭excel句柄
xl_obj.close()
if __name__ == '__main__':
xlwt_run()
没有使用类写,只是即兴而作。
来源:http://www.cnblogs.com/gide/p/8575249.html
0
投稿
猜你喜欢
- 测试环境win10python 3.5yield功能简介简单来说,yield 的作用就是把一个函数变成一个 generator,带有 yie
- python嵌套函数使用外部函数变量的方法,Python2和Python3均可使用python3 def b(): b = 1 def bc
- 问题描述:为了把之前的CPU版本的tensorflow卸载,换成GPU版本的tensorflow,经历了一番折腾。BUG1 Could no
- 例子: rsajax.js: var http_request = false; function makePOSTRequest(url,
- 泛型,如果你学过Java ,应该对它不陌生吧。但你可能不知道在 Python 中(3.4+ ),也可以实现简单的泛型函数。在Python中只
- 1.第一种就是直接调用 window.print()方法这种方法的坏处就是 默认打印整个页面,不能打印局部页面。2.第二种使用v-print
- 1、slice结构体首先我们来看一段代码package mainimport ( "fmt"
- sql xml 入门: --by jinjazz 1、xml: 能认识元素、属性和值 2、xpath: 寻址语言,类似windows目录的查
- 最近要做一个侧边目录的功能,没有找到类似的组件,索性自己写了一个供大家参考vue-side-catalog一个基于vue的侧边目录组件。源码
- CSS Type set是一款在线字体调整工具。你可以使用它来对字型进行排版调整并实时的看到CSS代码。在下图中,其中,你可以设置文本的字体
- 本文实例为大家分享了python实现12306图片验证效果的具体代码,供大家参考,具体内容如下思路:在鼠标点击位置加一个按钮,然后再按钮中的
- 实现html界面<!DOCTYPE html><html><head><title>Sele
- 示例代码,用到了函数substr与iconv_substr,mb_substr<html><head><met
- 声明:请事先到官网下载echarts,另外本文引用了adminlte模板构建前台页面views:<!-- /.row --> &
- 用 ASP (using jscript) 在服务端创建 GUID 的代码如下:function GUID(){ ret
- pytorch 预训练模型读取修改相关参数的填坑修改部分层,仍然调用之前的模型参数。resnet = resnet50(pretrained
- 本文实例为大家分享了JavaScript实现淘宝网图片的局部放大的具体代码,供大家参考,具体内容如下要实现的效果如下:<!DOCTYP
- 如下所示:# coding=utf-8# 用来处理数字,大于上限的数字置零f = open("/home/chuwei/桌面/tr
- 利用卷积神经网络训练图像数据分为以下几个步骤1.读取图片文件2.产生用于训练的批次3.定义训练的模型(包括初始化参数,卷积、池化层等参数、网
- 本文实例讲述了Python多线程应用于自动化测试操作。分享给大家供大家参考,具体如下:多线程执行测试用例实例:import threadin