Pycharm中安装Pygal并使用Pygal模拟掷骰子(推荐)
使用Python可视化Pygal包来生成可缩放的矢量图形文件!
对于在尺寸不同的屏幕上显示图标,它们将自动缩放以适合观看者的屏幕,如果以在线的方式使用图标,建议使用Pygal来生成,这样在任何设备上显示都会很美观!!!
1、安装Pygal
安装Pygal有好几种办法这边简略带过!!!
介绍一种在pycharm中直接安装的方法!
1、在File文件中打开Settings
2、找到Project:untitled打开Projiect lnterpreter右上方的+号
3、输入我们要安装的Pygal包,选中Specify version,点击左下方Install Package,出现绿色显示安装完成
4、查询下是否安装完成,在pycharm下方找到Terminal,并输入pip list,这时候我们查看到Pygal安装完成2.4.0版本。
2、Pypal画廊
了解使用Pygal可创建什么样的图标,可访问官网http://www.pygal.org/单击Documentation,再单击Chart types
3、创建Die类
下面的类模拟掷一个骰子:
创建die.py文件
from random import randint
class Die():
"""表示一个骰子的类"""
def __init__(self, num_sides=6): #_init_()接受一个可选参数,如果没有指定任何实参,面数默认为6
"""骰子默认为六面"""
self.num_sides = num_sides
def roll(self): #方法roll()使用randint()来返回
"""返回一个位于1和骰子面熟之间的随机值"""
return randint(1,self.num_sides)
4、掷骰子
使用Die类来掷骰子,将结果打印
新建一个die_visual.py文件
from matp.touzi.die import Die
#创建一个Die实例
die=Die()
#掷几次骰子,并将结果存储在一个列表中
results=[]
for roll_num in range(100):
result=die.roll()
results.append(result)
print(results)
通过对列表的打印,我们可以的下列结果集:
在效果图中我们可以看出,并未出现0和7的值所有结果有效
5、分析结果
在上述代码中,我们得到了骰子所有可能的列表,现在我们需要分析每个点出现的次数:
在die_visual.py文件添加修改:
from matp.touzi.die import Die
#创建一个Die实例
die=Die()
#掷几次骰子,并将结果存储在一个列表中
results=[]
for roll_num in range(1000):
result=die.roll()
results.append(result)
#分析结果
frequencies=[]
for value in range(1,die.num_sides+1):
frequency=results.count(value)
frequencies.append(frequency)
print(frequencies)
#print(results)
这边我们将掷骰子的次数增加到1000,同时创建了空列表frequencies,用来存储每个点出现的次数,再把值附加到frequencies末尾,我们将其效果打印,如下图所示:
6、绘制直方图
有了每个点数的次数列表之后,我们就可以绘制一个表示结果的直方图
在die_visual.py文件添加:
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling one D6 1000 times." #hist标题
hist.x_labels=['1','2','3','4','5','6']
hist.x_title="Result"
hist.y_title="Frequency of Result"
hist.add('D6',frequencies) #将一系列值添加到图标中
hist.render_to_file('die_visual.svg') #将图标渲染为一个svg文件
找到文件的地址,用浏览器打开die_visual.svg文件效果图如下所示:
7、同时掷两个骰子
前6点都是掷1个骰子,现在我们试着尝试同时掷两个骰子
我们只需对上面的die_visual.py文件进行修改即可,这边我们把die_visual.py文件复制一遍取一个新的文件名dice_visual.py,在dice_visual.py文件中进行修改。
from matp.touzi.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(1,max_result+1):
frequency=results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling two D6 1000 times." #hist标题
hist.x_labels=['2','3','4','5','6','7','8','9','10','11','12']
hist.x_title="Result"
hist.y_title="Frequency of Result"
hist.add('D6+D6',frequencies) #将一系列值添加到图标中
hist.render_to_file('dice_visual.svg') #将图标渲染为一个svg文件
#print(frequencies)
#print(results)
max_result=die_1.num_sides+die_2.num_sides
两个点数相加最大之和12,存储在max_result当中
效果图如下:
8、同时掷两个面数不同的骰子
上述第7点中掷的是两个相同的D6骰子,现实我们尝试着操作两个不同面得的骰子,掷这两个骰子50000次的结果如何。
新建different_dice.py文件
**from matp.touzi.die import Die
import pygal
#创建一个D6骰子和D10骰子
die_1=Die()
die_2=Die(10) #传递了第二个骰子实参为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(1,max_result+1):
frequency=results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling a D6 and a D10 50000 times." #hist标题
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_dice.svg') #将图标渲染为一个svg文件
#print(frequencies)
#print(results)**
效果图如下:
综上模拟掷骰子完毕!!!
附上完整的die.py和die_visual.py和dice_visual.py和different_dice.py文件
die.py
from random import randint
class Die():
"""表示一个骰子的类"""
def __init__(self, num_sides=6): #_init_()接受一个可选参数,如果没有指定任何实参,面数默认为6
"""骰子默认为六面"""
self.num_sides = num_sides
def roll(self): #方法roll()使用randint()来返回
"""返回一个位于1和骰子面熟之间的随机值"""
return randint(1,self.num_sides)
die_visual.py
from matp.touzi.die import Die
import pygal
#创建一个Die实例
die=Die()
#掷几次骰子,并将结果存储在一个列表中
results=[]
for roll_num in range(1000):
result=die.roll()
results.append(result)
#分析结果
frequencies=[]
for value in range(1,die.num_sides+1):
frequency=results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling one D6 1000 times." #hist标题
hist.x_labels=['1','2','3','4','5','6']
hist.x_title="Result"
hist.y_title="Frequency of Result"
hist.add('D6',frequencies) #将一系列值添加到图标中
hist.render_to_file('die_visual.svg') #将图标渲染为一个svg文件
#print(frequencies)
#print(results)
dice_visual.py
from matp.touzi.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(1,max_result+1):
frequency=results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling two D6 1000 times." #hist标题
hist.x_labels=['2','3','4','5','6','7','8','9','10','11','12']
hist.x_title="Result"
hist.y_title="Frequency of Result"
hist.add('D6+D6',frequencies) #将一系列值添加到图标中
hist.render_to_file('dice_visual.svg') #将图标渲染为一个svg文件
#print(frequencies)
#print(results)
different_dice.py
from matp.touzi.die import Die
import pygal
#创建一个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(1,max_result+1):
frequency=results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist=pygal.Bar() #创建一个实例,并将其储存在hist中
hist.title="Result of rolling a D6 and a D10 50000 times." #hist标题
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_dice.svg') #将图标渲染为一个svg文件
#print(frequencies)
#print(results)
总结
到此这篇关于Pycharm中安装Pygal并使用Pygal模拟掷骰子的文章就介绍到这了,更多相关Pycharm安装Pygal模拟掷骰子内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持ZaLou.Cn!
- boi剖析 - 基于webpack的css sprites实现方案
- 深入JDK源码之ThreadLocal类
- 独家 | 一文读懂TensorFlow基础
- Webpack中hash与chunkhash的区别,以及js与css的hash指纹解耦方案
- RPC原理及实现
- RMI原理及实现
- webpack多页面开发与懒加载hash解决方案
- 前后端分离和模块化-58到家微信首页重构之路
- Node.js建站笔记-使用react和react-router取代Backbone
- 协同过滤推荐算法Java代码实现
- Nginx模块之Filter解析
- Nodejs建站笔记-注册登录流程的简单实现
- 前端工程化-构建
- [翻译]开发Silverlight 2.0的自定义控件
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法