使用的是pygal函数库 所以需要先安装
1 安装库文件
pip install pygal=1.7
2 创建骰子类
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)
3 2个不同面的骰子成的直方图
import pygal from die import Die #创建1个D6和一个D10 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 = [] max_result = die_1.num_sides + die_2.num_sides for value in range(2, max_result): frequencie = results.count(value) frequencies.append(frequencie) #对结果进行可视化 hist = pygal.Bar() hist.title = "Results of rolling one D6 and one 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) hist.render_to_file('different_visual.svg')
4 结果实例