pygal库的使用

6937次阅读 73人点赞 作者: WuBin 发布时间: 2025-03-07 08:58:42
扫码到手机查看

pygal

可视化包 pygal可以生成可缩放的矢量图形文件,如果是以在线方式使用图表,请考虑使用pygal来生成它们。因为它将自动缩放,以便适应观看者屏幕。

要直到可以创建什么样的图表,查看:https://www.pygal.org/en/stable/

列表中常用的方法:参考

安装

如果是非虚拟环境

python -m pip install --user pygal==1.7

比如我本地使用了虚拟环境:

(venv) D:\python-work\py-bigdata>python -m pip install pygal==1.7

如果需要安装最新版本:

python -m pip install pygal

查看是否可用:

import pygal
print(pygal.__version__)

使用pygal

创建类模拟骰子pygal_die.py

from random import randint

class Die():
    """表示一个骰子的类"""

    def __init__(self, num_sides=6):
        """骰子默认为6面"""
        self.num_sides = num_sides
        pass

    def roll(self):
        """返回一个位于1和骰子面数之间的随机值 1~self.num_sides之间的任意值"""
        return randint(1, self.num_sides)

from random import randint:randint(min,max)可以返回min~max之间的一个随机整数。

下面来测试一下这个类:

from pygal_die import Die

die = Die()

results = []
for roll_num in range(100):
    result = die.roll()
    results.append(result)

print(results)

循环100次,可以看到值在1-6之间,都处于正确范围内。

分析结果,统计每个数字出现了几次

from pygal_die import Die

die = Die()

results = []
# 循环1000次 每次掷骰子 生成1-6之间的随机数 存入results中
for roll_num in range(1000):
    result = die.roll()
    results.append(result)

# 用于存储每种点数出现的次数
frequencies = []
# 遍历可能的点数(1~6)range(min, max),如要包含max,那么就需要range(min, max + 1)
# 这里循环6次
for value in range(1, die.num_sides+1):
    # 使用列表的count方法统计results列表中value出现的次数,并将结果存储在frequency变量中。
    # 因为value分别是1~6 所以 分别统计results中1出现了几次、...6出现了几次
    frequency = results.count(value)
    # 并将出现的次数添加到数组中
    frequencies.append(frequency)

print(frequencies)

现在我们使用pygal将数据使用直方图展示,最终效果以及代码如下:

import pygal
from pygal_die import Die

die = Die()

results = []
# 循环1000次 每次掷骰子 生成1-6之间的随机数 存入results中
for roll_num in range(1000):
    result = die.roll()
    results.append(result)

# 用于存储每种点数出现的次数
frequencies = []
# 遍历可能的点数(1~6)range(min, max),如要包含max,那么就需要range(min, max + 1)
# 这里循环6次
for value in range(1, die.num_sides+1):
    # 使用列表的count方法统计results列表中value出现的次数,并将结果存储在frequency变量中。
    # 因为value分别是1~6 所以 分别统计results中1出现了几次、...6出现了几次
    frequency = results.count(value)
    # 并将出现的次数添加到数组中
    frequencies.append(frequency)

hist = pygal.Bar()

hist.title = "骰子掷1000次计数统计"
hist.x_labels = ['1', '2', '3', '4', '5', '6']
hist.x_title = "结果"
hist.y_title = '次数统计'

# a将一系列值加入到图表中 frequencies的值会与hist.x_labels 相对应
hist.add('D6', frequencies)
# 将图表渲染未svg文件 pygal生成的svg图表具有交互性
hist.render_to_file('die_visual.svg')
注意,如果你使用py版本较高,那么之前推荐安装的1.7版本的pygal在这里会产生运行问题,就需要升级到最新版本:pipinstall--upgradepygal

投掷两个骰子

# 同时投掷两个骰子
import pygal
from pygal_die import Die

# 创建两个D6骰子
die_1 = Die()
die_2 = Die()

results = []
for roll_num in range(1000):
    result = die_1.roll() + die_2.roll()
    results.append(result)


frequencies = []
# 两个骰子 最大点数就是6+6
max_result = die_1.num_sides + die_2.num_sides
for value in range(1, max_result+1):
    frequency = results.count(value)
    frequencies.append(frequency)

hist = pygal.Bar()

hist.title = "两个骰子投掷1000次 点数统计"
# 两个骰子正常情况下最小就是2
hist.x_labels = ['2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12']
hist.x_title = "结果"
hist.y_title = '次数统计'

hist.add('D6 + D6', frequencies)
hist.render_to_file('dice_visual.svg')

投掷一个6面骰子和10面骰子

# 同时投掷两个骰子 一个6面骰子 一个10面骰子
import pygal
from pygal_die import Die

# 创建两个D6骰子
die_1 = Die()
die_2 = Die(10)

results = []
for roll_num in range(50000):
    result = die_1.roll() + die_2.roll()
    results.append(result)


frequencies = []
# 两个骰子 最大点数就是6+6
max_result = die_1.num_sides + die_2.num_sides
for value in range(1, max_result+1):
    frequency = results.count(value)
    frequencies.append(frequency)

hist = pygal.Bar()

hist.title = "6面骰子和10面骰子投掷5万次"
# D6 + D10 最小是2,最大是16(6+10)
hist.x_labels = ['2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16']
hist.x_title = "结果"
hist.y_title = '次数统计'

hist.add('D6 + D10', frequencies)
hist.render_to_file('different_dice.svg')

自定义工具提示

pygal中,将鼠标指向条形将显示它表示的信息,称为工具提示。

直接看下面这个例子

import pygal

"""
pygal中,将鼠标指向条形将显示它表示的信息,称为工具提示
"""

from pygal.style import LightColorizedStyle as LCS, LightenStyle as LS

my_style = LS('#333366', base_style=LCS)
chart = pygal.Bar(style=my_style, x_label_rotation=45, show_legend=False)

chart.title = 'PY项目'
chart.x_labels = ['httpie', 'django', 'flask']

# 对于自定义工具提示,是有明确格式要求的
plot_dicts = [
    # 根据value确定柱状图高度 是必须的  label键是可选的 用于显示自定义文本 其他可选键(如xlink、color等)可用于进一步定制
    { 'value': 16101, 'label': 'httpie的描述' },
    { 'value': 15028, 'label': 'django的描述' },
    { 'value': 14798, 'label': 'flask的描述' }
]
# 自定义提示的唯一方式是通过label键或配置全局的tooltip_formatter函数。

# add接受一个字符串和一个列表
chart.add('', plot_dicts)
chart.render_to_file('bar_descriptions.svg')

chart.add(字符串,列表)用于自定义提示

字符串:

chart.add()方法的第一个参数字符串是系列名称,主要作用是:

1.图例(Legend)显示

  • show_legend=True(默认值)时,系列名称会显示在图表的图例中,标识不同的数据系列。
  • 在你的代码中,show_legend=False,因此该参数不会在图例中显示,但仍会作为工具提示的一部分。

2.工具提示(Tooltip)的前缀

  • 当鼠标悬停在数据点上时,系列名称会作为前缀显示在工具提示中。
系列名称参数工具提示显示效果
chart.add('数据', ...)数据: A的描述 (10)
chart.add('', ...)B的描述 (20) 

总结:第一个参数字符串的主要作用:图例显示和工具提示前缀。

列表:

需要特别注意的是,对于自定义工具提示,传入的字典必须有严格的格式要求。

如果要添加自定义描述,label是不可或缺的,如果不需要那么这个字段可以省略。

value指的是要渲染的图表的数值,是必须的。

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:pygal
推荐阅读
  • python基础-操作列表和迭代器

    python基础笔记-操作列表和迭代器的相关方法

    6357次阅读 141人点赞 发布时间: 2024-06-13 13:26:27 立即查看
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    10891次阅读 729人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    14845次阅读 597人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    13794次阅读 1108人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    17871次阅读 1432人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    16077次阅读 1298人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    31566次阅读 2485人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    27645次阅读 2135人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录