侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

python xlsxwriter创建excel图表的方法

Python  /  管理员 发布于 7年前   487

本文实例为大家分享了python xlsxwriter创建excel图表的具体代码,供大家参考,具体内容如

#coding=utf-8 import xlsxwriter from xlsxwriter.workbook import Workbook from xlrd.sheet import Sheet  def demo1():  import xlsxwriter    # 创建excel文件  workbook = xlsxwriter.Workbook('demo.xlsx') #  添加worksheet,也可以指定名字  worksheet = workbook.add_worksheet()  worksheet = workbook.add_worksheet('Test')    #设置第一列的宽度  worksheet.set_column('A:A', len('hello ')+1)    #添加一个加粗格式方便后面使用  bold = workbook.add_format({'bold': True})    #在A1单元格写入纯文本  worksheet.write('A1', 'Hello')    #在A2单元格写入带格式的文本  worksheet.write('A2', 'World', bold)    #指定行列写入数字,下标从0开始  worksheet.write(2, 0, 123)  worksheet.write(3, 0, 123.456)    #在B5单元格插入图片  worksheet.insert_image('B5', 'python-logo.png')      workbook.close()     def charts():  workbook = xlsxwriter.Workbook('chart_column.xlsx')  worksheet = workbook.add_worksheet()  bold = workbook.add_format({'bold': 1})    # 这是个数据table的列  headings = ['Number', 'Batch 1', 'Batch 2']  data = [   [2, 3, 4, 5, 6, 7],   [10, 40, 50, 20, 10, 50],   [30, 60, 70, 50, 40, 30],  ]  #写入一行  worksheet.write_row('A1', headings, bold)  #写入一列  worksheet.write_column('A2', data[0])  worksheet.write_column('B2', data[1])  worksheet.write_column('C2', data[2])        ############################################  #创建一个图表,类型是column  chart1 = workbook.add_chart({'type': 'column'})    # 配置series,这个和前面worksheet是有关系的。 #  指定图表的数据范围  chart1.add_series({   'name':  '=Sheet1!$B$1',   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$B$2:$B$7',  })  chart1.add_series({   'name':  "=Sheet1!$C$1",   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$C$2:$C$7',  }) # 配置series的另一种方法  #  #  [sheetname, first_row, first_col, last_row, last_col] #  chart1.add_series({ #   'name':   ['Sheet1',0,1], #   'categories': ['Sheet1',1,0,6,0], #   'values':  ['Sheet1',1,1,6,1], #      }) #   # # #  chart1.add_series({ #   'name':  ['Sheet1', 0, 2], #   'categories': ['Sheet1', 1, 0, 6, 0], #   'values':  ['Sheet1', 1, 2, 6, 2], #  })    #  添加图表标题和标签  chart1.set_title ({'name': 'Results of sample analysis'})  chart1.set_x_axis({'name': 'Test number'})  chart1.set_y_axis({'name': 'Sample length (mm)'})    # 设置图表风格  chart1.set_style(11)     # 在D2单元格插入图表(带偏移)  worksheet.insert_chart('D2', chart1, {'x_offset': 25, 'y_offset': 10})    #######################################################################  #  # 创建一个叠图子类型  chart2 = workbook.add_chart({'type': 'column', 'subtype': 'stacked'})    # Configure the first series.  chart2.add_series({   'name':  '=Sheet1!$B$1',   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$B$2:$B$7',  })    # Configure second series.  chart2.add_series({   'name':  '=Sheet1!$C$1',   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$C$2:$C$7',  })    # Add a chart title and some axis labels.  chart2.set_title ({'name': 'Stacked Chart'})  chart2.set_x_axis({'name': 'Test number'})  chart2.set_y_axis({'name': 'Sample length (mm)'})    # Set an Excel chart style.  chart2.set_style(12)    # Insert the chart into the worksheet (with an offset).  worksheet.insert_chart('D18', chart2, {'x_offset': 25, 'y_offset': 10})    #######################################################################  #  # Create a percentage stacked chart sub-type.  #  chart3 = workbook.add_chart({'type': 'column', 'subtype': 'percent_stacked'})    # Configure the first series.  chart3.add_series({   'name':  '=Sheet1!$B$1',   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$B$2:$B$7',  })    # Configure second series.  chart3.add_series({   'name':  '=Sheet1!$C$1',   'categories': '=Sheet1!$A$2:$A$7',   'values':  '=Sheet1!$C$2:$C$7',  })    # Add a chart title and some axis labels.  chart3.set_title ({'name': 'Percent Stacked Chart'})  chart3.set_x_axis({'name': 'Test number'})  chart3.set_y_axis({'name': 'Sample length (mm)'})    # Set an Excel chart style.  chart3.set_style(13)    # Insert the chart into the worksheet (with an offset).  worksheet.insert_chart('D34', chart3, {'x_offset': 25, 'y_offset': 10})  #生成圆饼图  chart4 = workbook.add_chart({'type':'pie'})  #定义数据  data = [    ['Pass','Fail','Warn','NT'],    [333,11,12,22],    ]  #写入数据  worksheet.write_row('A51',data[0],bold)  worksheet.write_row('A52',data[1])    chart4.add_series({     'name':   '接口测试报表图',   'categories': '=Sheet1!$A$51:$D$51',   'values':  '=Sheet1!$A$52:$D$52',   'points':[    {'fill':{'color':'#00CD00'}},    {'fill':{'color':'red'}},    {'fill':{'color':'yellow'}},    {'fill':{'color':'gray'}},      ],  })  # Add a chart title and some axis labels.  chart4.set_title ({'name': '接口测试统计'})  chart4.set_style(3)  #  chart3.set_y_axis({'name': 'Sample length (mm)'})    worksheet.insert_chart('E52', chart4, {'x_offset': 25, 'y_offset': 10})  workbook.close() if __name__ == '__main__': #  demo1()  charts()  print('finished...')  pass 

效果如下

参考文档:

https://pypi.python.org/pypi/XlsxWriter

python使用xlsxwriter打造excel周报日周的统计图表

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    Python3中的列表生成式、生成器与迭代器实例详解
    下一条:
    python操作excel的包(openpyxl、xlsxwriter)
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客