5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

Wesley13
• 阅读 698

点击上方“Python爬虫与数据挖掘”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

醉卧沙场君莫笑,古来征战几人回?

有时候我们做数据可视化并不需要特别复杂的功能,仅仅是想把简单的数据用图形展示出来

今天就给大家介绍一种非常适合新手的python可视化库--pygal

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

pygal比较小众,专注于SVG图,擅长交互,最主要的是它能用非常少的代码就可画出非常漂亮的图形

pygal能绘制Line(折线图)、Bar(柱状图)、Histogram(直方图)、Pie(饼图)、Radar(雷达图)、Funnel(漏斗图)、Gauge(仪表盘图)等14种常见可视化图

而且自带16种漂亮的主题,色调相当柔和,感觉很适合我这样细腻温柔的人

pygal的安装比较简单,直接在命令行输入以下代码即可:

pip install pygal

下面,我们依托某宿舍2020年各月生活费花销情况为例,对pygal绘制方法进行介绍

首先pandas读取数据:

import pandas as pddata=pd.read_excel('生活费开销.xlsx')

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

我想在jupyter上直接显示pygal的图形,需要创建html的基础模板,你们可以拿去直接用:

import pygal#设置pygal与jupyter notebook交互from IPython.display import display, HTMLbase_html = """<!DOCTYPE html><html>  <head>  <script type="text/javascript" src="http://kozea.github.com/pygal.js/javascripts/svg.jquery.js"></script>  <script type="text/javascript" src="https://kozea.github.io/pygal.js/2.0.x/pygal-tooltips.min.js""></script>  </head>  <body>    <figure>      {rendered_chart}    </figure>  </body></html>"""

下面进入主题:

1.pygal绘制折线图(主题:DefaultStyle)

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()line_chart = pygal.Line(style=DefaultStyle)line_chart.title = '520寝室2020年生活费花销情况'line_chart.x_labels = labelfor i in people:    line_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=line_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

2.pygal绘制柱状图(主题:DarkStyle、NeonStyle)


绘制竖状柱状图

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()line_chart = pygal.Bar(style=DarkStyle)line_chart.title = '520寝室2020年生活费花销情况'line_chart.x_labels = labelfor i in people:    line_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=line_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

绘制横状柱状图

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()line_chart = pygal.HorizontalBar(style=NeonStyle)line_chart.title = '520寝室2020年生活费花销情况'line_chart.x_labels = labelfor i in people:    line_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=line_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

3.pygal绘制饼图(主题:DarkSolarizedStyle)

普通饼状图

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()line_chart = pygal.Pie(style=DarkSolarizedStyle)line_chart.title = '520寝室2020年1月生活费花销情况'line_chart.x_labels = labelfor i in people:    line_chart.add(i, data[(data.人员==i)&(data.月份=='1月')]['花销'].values.tolist())HTML(base_html.format(rendered_chart=line_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

圆环图

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()pie_chart = pygal.Pie(inner_radius=0.45,style=LightSolarizedStyle)pie_chart.title = '520寝室2020年1月生活费花销情况'for i in people:    pie_chart.add(i, data[(data.人员==i)&(data.月份=='1月')]['花销'].values.tolist()[0])HTML(base_html.format(rendered_chart=pie_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

4.pygal绘制雷达图(主题:LightStyle)


from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()radar_chart = pygal.Radar(style=LightStyle)radar_chart.title = '520寝室2020年生活费花销情况'radar_chart.x_labels = labelfor i in people:    radar_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=radar_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

5.pygal绘制箱形图(主题:CleanStyle)

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()box_plot = pygal.Box(style=CleanStyle)box_plot.title = '520寝室2020年生活费花销情况'for i in people:    box_plot.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=box_plot.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

6.pygal绘制散点图(主题:RedBlueStyle)

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()dot_chart = pygal.Dot(x_label_rotation=30,style=RedBlueStyle)dot_chart.title = '520寝室2020年生活费花销情况'dot_chart.x_labels=labelfor i in people:    dot_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=dot_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

7.pygal绘制漏斗图(主题:DarkColorizedStyle)

from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()funnel_chart = pygal.Funnel(style=DarkColorizedStyle)funnel_chart.title = '520寝室2020年生活费花销情况'funnel_chart.x_labels=labelfor i in people:    funnel_chart.add(i, data[data.人员==i]['花销'].values.tolist())HTML(base_html.format(rendered_chart=funnel_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

8.pygal绘制仪表盘图(主题:LightColorizedStyle)


from pygal.style import *people=data['人员'].unique()label=data['月份'].unique()gauge_chart = pygal.Gauge(human_readable=True,style=LightColorizedStyle)gauge_chart.title = '520寝室2020年1月生活费花销情况'gauge_chart.range = [0, 5000]for i in people:    gauge_chart.add(i, data[(data.人员==i)&(data.月份=='1月')]['花销'].values.tolist())HTML(base_html.format(rendered_chart=gauge_chart.render(is_unicode=True)))#图片渲染

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

细心的读者可以发现,pygal绘制图形的套路基本都一样,其核心的代码也就5行代码,可以说是一招打遍天下无敌手。

**********---**--****-------------- End **********---**--****--------------

往期精彩文章推荐:

5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了

欢迎大家点赞,留言,转发,转载,****感谢大家的相伴与支持

想加入Python学习群请在后台回复【入群

万水千山总是情,点个【在看】行不行

/今日留言主题/

随便说一两句吧~~

本文分享自微信公众号 - Python爬虫与数据挖掘(crawler_python)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Irene181 Irene181
3年前
盘点最重要的7个Python库
点击上方“Python爬虫与数据挖掘”,进行关注回复“书籍”即可获赠Python从入门到进阶共10本电子书导读:对于那些对Python数据生态系统不太熟悉的人士,我将简要地介绍一部分重要的库。作者:韦斯·麦金尼(WesMcKinney)译者:徐敬来源:大数据DT(ID:hzdashuju)01NumPyhttp://numpy
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Karen110 Karen110
3年前
5行代码搞定14种常见图的python可视化库,还自带16种优美主题,真是太喜欢了
有时候我们做数据可视化并不需要特别复杂的功能,仅仅是想把简单的数据用图形展示出来今天就给大家介绍一种非常适合新手的python可视化库pygalpygal比较小众,专注于SVG图,擅长交互,最主要的是它能用非常少的代码就可画出非常漂亮的图形pygal能绘制Line(折线图)、Bar(柱状图)、Histogram(直方图)、Pie(饼图)、Radar(雷达
Stella981 Stella981
3年前
25条很棒的Python一行代码,建议收藏!
点击上方“Python爬虫与数据挖掘”,进行关注回复“书籍”即可获赠Python从入门到进阶共10本电子书今日鸡汤中岁颇好道,晚家南山陲。自从我用Python编写第一行代码以来,就被它的简单性、出色的可读性和特别流行的一行代码所吸引。在下面,我将给大家介绍并解释一些Python一行程序。
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
3年前
Python分析《哈哈哈哈哈》47687条弹幕,看看大家都在说些啥!
点击上方“Python爬虫与数据挖掘”,进行关注回复“书籍”即可获赠Python从入门到进阶共10本电子书今日鸡汤归山深浅去,须尽丘壑美。!(https://oscimg.oschina.net/oscnet/5a50ee167263416384471dc0bf419cee.png)图片来源:豆瓣
可莉 可莉
3年前
10行Python代码自动清理电脑内重复文件,解放双手!
点击上方“Python爬虫与数据挖掘”,进行关注回复“书籍”即可获赠Python从入门到进阶共10本电子书今日鸡汤世间行乐亦如此,古来万事东流水。!(https://oscimg.oschina.net/oscnet/da5385ecbd59492aa127c14a1a5b807c.jpg)(h
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这