使用Pygal模拟掷骰子
Pygal官网:http://www.pygal.org/
- 创建一个Die类
from random import randint class Die(): """表示一个骰子的类""" def __init__(self,num_sides = 6): """骰子默认为6面""" self.num_sides = num_sides def roll(self): """返回一个位于1和骰子面数之间的随机值""" return randint(1,self.num_sides)
- 生成结果直方图
from die import Die import pygal #创建一个D6 一个D10 die_1 = Die() die_2 = Die(10) #掷几次骰子,并将结果存储在一个列表中 results = [] #5000次 for roll_num in range(5000): 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): frequency = results.count(value)#count方法统计列表中某一项出现的次数 frequencies.append(frequency) #对结果进行可视化 hist = pygal.Bar() hist.title = "Results of rolling a D6 and a D10 50000 times" hist.x_labels = ['2','3','4','5','6','7','8','9','10','11','12','13','14','15','16'] hist.x_title = "Result" hist.y_title = "Frequency of Result" hist.add("D6+D10",frequencies) #渲染为svg文件 hist.render_to_file('die_visual.svg')