说明:以下所有的程序都来自于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来创建直方图,以及如何使用直方图来探索掷骰子的过程。