用Pygal繪制直方圖代碼示例
Pygal可用來生成可縮放的矢量圖形文件,對于需要在尺寸不同的屏幕上顯示的圖表,這很有用,可以自動縮放,自適應(yīng)觀看者的屏幕
1、Pygal模塊安裝
pygal的安裝這里暫不介紹,大家可參閱《pip和pygal的安裝實例教程》
2、Pygal畫廊-直方圖
模擬擲骰子,分析最后的結(jié)果,生成圖形
創(chuàng)建die.py篩子類文件:
from random import randint
class Die():
'''扔骰子的類'''
def __init__(self,num_sides=6):
self.num_sides = num_sides # 骰子的面數(shù)
def roll(self):
return randint(1,self.num_sides)
創(chuàng)建die_visual.py文件,生成直方圖:
from die import Die
import pygal
die = Die()
# 數(shù)據(jù)集合
results = []
count = 1
for roll_num in iter(lambda *args:die.roll(),None):
results.append(roll_num)
if count >= 1000:
break
count +=1
# 分析結(jié)果
frequencies= []
for value in range(1,die.num_sides+1):
frequencie = results.count(value)
frequencies.append(frequencie)
# 對結(jié)果進行可視化
hist = pygal.Bar() # 生成實例
hist.title = 'Results of rolling one D6 1000 times' # 標題
hist.x_labels = ['1','2','3','4','5','6'] # X軸數(shù)值坐標
hist.x_title = 'Result' # X軸標題
hist.y_title = 'Frequency of Result' # Y軸標題
hist.add('D6',frequencies) # 傳入Y軸數(shù)據(jù)
hist.render_to_file('die_visual.svg') # 文件生成路徑,必須為svg格式文件
通過瀏覽器打開die_visual.svg文件:

3、同時擲兩枚骰子
修改die_visual.py文件:
from die import Die
import pygal
die1 = Die()
die2 = Die()
# 數(shù)據(jù)集合
results = []
for i in range(5000):
result = die1.roll() + die2.roll()
results.append(result)
# 分析結(jié)果
frequencies= []
for value in range(2,die1.num_sides+die2.num_sides+1):
frequencie = results.count(value)
frequencies.append(frequencie)
# 對結(jié)果進行可視化
hist = pygal.Bar() # 生成實例
hist.title = 'Results of rolling one D6 5000 times' # 標題
hist.x_labels = ['2','3','4','5','6','7','8','9','10',11,12] # X軸數(shù)值坐標
hist.x_title = 'Result' # X軸標題
hist.y_title = 'Frequency of Result' # Y軸標題
hist.add('D6+D6',frequencies) # 傳入Y軸數(shù)據(jù)
hist.render_to_file('die_visual.svg') # 文件生成路徑,必須為svg格式文件
瀏覽器瀏覽圖形die_visual.svg:

總結(jié)
以上就是本文關(guān)于用Pygal繪制直方圖代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
利用Python第三方庫xlrd讀取Excel中數(shù)據(jù)實例代碼
python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫,下面這篇文章主要給大家介紹了關(guān)于利用Python第三方庫xlrd讀取Excel中數(shù)據(jù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-07-07
Python?multiprocessing.value實現(xiàn)多進程數(shù)據(jù)共享的示例
本文介紹了Python中的multiprocessing.value,通過示例代碼展示了如何使用這個類實現(xiàn)多進程數(shù)據(jù)共享,以及使用場景和注意事項等內(nèi)容,感興趣的朋友跟隨小編一起看看吧2023-07-07
python GUI庫圖形界面開發(fā)之PyQt5信號與槽的高級使用技巧裝飾器信號與槽詳細使用方法與實例
這篇文章主要介紹了python GUI庫圖形界面開發(fā)之PyQt5信號與槽的高級使用技巧裝飾器信號與槽詳細使用方法與實例,需要的朋友可以參考下2020-03-03

