其實很簡單,就是算了一下百分比權重,乘以了一個權重值
import matplotlib.pyplot as plt
from matplotlib.ticker import FuncFormatter
from numpy.random import randn
from matplotlib.font_manager import FontProperties
def to_percent(y,position):
return str(100*y)+"%"#這里可以用round()函數設置取幾位小數
font=FontProperties(fname='/Library/Fonts/Songti.ttc')#這里設置字體,可以顯示中文
x=randn(1000)
plt.hist(x,bins=30,weights=[1./len(x)]*len(x))#這里weights是每一個數據的權重,這里設置是1,weights是和x等維的列表或者series
fomatter=FuncFormatter(to_percent)
plt.gca().yaxis.set_major_formatter(fomatter)
plt.title("頻率分布直方圖")
plt.show()