Pygal可视化包

说明:以下所有的程序都来自于Eric Matthes 的书《Python编程从入门到实践》
使用python可视化包pygal来生成可缩放的矢量图形文件
1.安装pygal
pycharm中 file-settings-project interpreter-+pygal
2.使用pygal模拟掷骰子

创建骰子类Die

from random import randint
class Die():
     '''一个表示骰子的类'''
     def __init__(self,num_sides=6):

         '''骰子默认为6面D6'''
         self.num_sides=num_sides

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

掷骰子

from die import Die
import pygal
#创建一个D6
die =Die()

#掷骰子,将结果存在列表中
results=[]

#for roll_num in range(100):
   # result =die.roll() #产生一百个1到6 的随机数
   # results.append(result)
#print(results)

for roll_num in range(1000): #产生一千个随机点数
    result =die.roll()
    results.append(result)

#分析结果
frequencies=[] #列表,记录每个点出现的次数
for value in range(1,die.num_sides+1): #遍历1到6的点数
    frequency = results.count(value) #计算每种点数在results中出现的次数
    frequencies.append(frequency)
print(frequencies)

#分析结果 对结果进行可视化 绘制频率直方图histogrom
hist =pygal.Bar() #创建一个pygal.Bar()实例
hist.title ="Results of rolling one D6 1000 times"
hist.x_labels = ['1','2','3','4','5','6']#标签
hist.x_title= "Results"
hist.y_title ="Frequency of Result"
hist.add('D6',frequencies) #将一系列的值加到图表中,传递标签“D6”和一个列表(包含所有的值)
hist.render_to_file("die_visial.svg")#渲染为svg格式的直方图

一个六面骰子
3.同时掷两个骰子

from die import Die
import pygal
#创建两个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=[] #列表,记录每个点出现的次数
max_result = die_1.num_sides+die_2.num_sides
for value in range(2,max_result+1): #遍历1到6的点数
    frequency = results.count(value) #计算每种点数在results中出现的次数
    frequencies.append(frequency)
print(frequencies)

#分析结果 对结果进行可视化 绘制频率直方图histogrom
hist =pygal.Bar() #创建一个pygal.Bar()实例
hist.title ="Results of rolling two D6  dice 1000 times"
hist.x_labels = [x for x in range(2,13)]#标签
hist.x_title= "Results"
hist.y_title ="Frequency of Result"
hist.add('D6+D6',frequencies) #将一系列的值加到图表中,传递标签“D6+D6”和一个列表(包含所有的值)
hist.render_to_file("die_visial.svg")#渲染为svg格式的直方图

两个相同的六面骰子
4.同时掷两个面数不同的骰子

from die import Die
import pygal #可视化包
#创建一个D6和一个D10
die_1 =Die()
die_2 =Die(10)

#掷骰子,将结果存在列表中
results=[]


for roll_num in range(3000): #产生三千个随机点数
    result =die_1.roll()+die_2.roll()
    results.append(result)

#分析结果
frequencies=[] #列表,记录每个点出现的次数
max_result = die_1.num_sides+die_2.num_sides
for value in range(2,max_result+1): #遍历1到6的点数
    frequency = results.count(value) #计算每种点数在results中出现的次数
    frequencies.append(frequency)
print(frequencies)

#分析结果 对结果进行可视化 绘制频率直方图histogrom
hist =pygal.Bar() #创建一个pygal.Bar()实例
hist.title ="Results of rolling  a D6 and a D10 3000 times"
hist.x_labels = [x for x in range(2,17)]#标签
hist.x_title= "Results"
hist.y_title ="Frequency of Result"
hist.add('D6+D10',frequencies) #将一系列的值加到图表中,传递标签“D6+D10”和一个列表(包含所有的值)
hist.render_to_file("die_visial.svg")#渲染为svg格式的直方图

一个六面一个十面的骰子
通过这一节学习了,如何使用matplotlib创建简单的图表(折线图,曲线图等),以及如何使用散点图来探索随机漫步的过程,如何使用pygal来创建直方图,以及如何使用直方图来探索掷骰子的过程。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值