Sci*_*ion 3 python margins matplotlib
我试图绘制一个水平堆积条形图,但在顶部和底部获得令人讨厌的大边距。我想摆脱它或控制大小。
这是一个示例代码和图:
from random import random
Y = ['A', 'B', 'C', 'D', 'E','F','G','H','I','J', 'K']
y_pos = np.arange(len(Y))
data = [(r, 1-r) for r in [random() for i in range(len(Y))]]
print data
a,b = zip(*data)
fig = plt.figure(figsize=(8,16))
ax = fig.add_subplot(111)
ax.barh(y_pos, a,color='b',align='center')
ax.barh(y_pos, b,left=a,color='r',align='center')
ax.set_yticks(y_pos)
ax.set_yticklabels(Y, size=16)
ax.set_xlabel('X label', size=20)
plt.xlim(0,1) #removing the extra x on the right side
Run Code Online (Sandbox Code Playgroud)
如果要重新创建确切的数字,请对创建附加数字(“数据”)的序列进行采样:
[(0.2180251581652276,0.7819748418347724),(0.20639063565084814,0.7936093643491519),(0.5402540115461549,0.45974598845384507),(0.39283183355790896,0.607168166442091),(0.5082547993681953,0.4917452006318047),(0.02489004061858613,0.9751099593814139),(0.25902114354397665,0.7409788564560233),(0.12032683729286475,0.8796731627071352),( 0.41578415717252204, 0.584215842827478), (0.5860546624151288, 0.4139453375848712), (0.20982525842827478), (0.20982523737740)4052373774040

我希望在“K”顶部以及 x 轴和“A”之间有一个更小的间隙。如果我将 16 更改为:
fig = plt.figure(figsize=(8,16))
Run Code Online (Sandbox Code Playgroud)
到 10 一切都在缩小,但利润率仍然比较大。
有任何想法吗?谢谢!
您可能希望将此行添加到脚本的末尾:
plt.ylim(min(y_pos)-1, max(y_pos)+1)
Run Code Online (Sandbox Code Playgroud)
这会将边距减少到半条宽度。
| 归档时间: |
|
| 查看次数: |
1368 次 |
| 最近记录: |