python怎么画一个点_?用Python把图做的好看点:用Matplotlib画个好看的气泡图

73f42a37f135dca0050379123feb35d9.png

我们继续来把简单的图形丢到极坐标,这次是气泡图和柱状图,临摹的对象是澎湃美数课

8515f6b5e87ab4b7ec711215f8bf1a8d.png

这个图看起来很好看,原理其实很简单,把柱状图和气泡图从笛卡尔坐标系中转移到极坐标系中来就OK

我们开始本次的临摹吧

本期的主题如下:

  • 熟悉一下柱状图的一些参数
  • 熟悉一下散点图的一些参数
  • 熟悉一下极坐标系的规则(高中内容啦)
  • 熟悉一下这么自定义字体
  • 熟悉一下网格线

我们先来说说及极坐标内,一个点位置该怎么表示:(笔者很懒惰,就直接从网上复制图片来教学了)

0f0b153b13251a462a7c6f87eca6f777.png

从图上可以看出来,x轴为那个带箭头的线,matplotlib中也一样,极坐标的起点在同样的位置,不过在matplotlib里 x表示的是角度,y表示的长度,所以确定好夹角θ,和半径长度就OK

我们在看看 美术课里这个样图,一排上,一共有15个圆,且最后一个和第一个没有在90°与270°的位置上,所以我们要把圆分成36份,也就是每份是2π/36

这样我们就可以确定等差数列了,我们以3/2π为起点,不断加2π/36

我们来画第一圈圆

import 

9b204e7aaebf70c415490935721c7113.png
第一圈圆
S2=np.array([2028,1976,1962,1925,1904,1833,1730,1577,1524,1493,1475,1589,1511,1505,1524])*2
x2=[(0)*np.pi+np.pi/(len(S1)+1)*(i+1) for i in range(2*(len(S1)+1))]
y2=[130 for i in range(2*(len(S1)+1)) if i<len(S1) ]

我们用同样的方式计算出第二圈圆的位置,画出来

54d812d2f2a187f1b8c51da3a3f3885a.png

接着我们把柱状图也丢进极坐标掰弯

柱状图可以用四个参数来确定每个柱子的位置

H1=[56,55,54,52,51,50,49,47,43,40,37,34,31,28,24]
W1=[0.05 for i in range(2*(len(S1)+1)) if i<len(S1)]
B=[30 for i in range(2*(len(S1)+1)) if i<len(S1)]

ax.bar(x=x1, height=H1, width=W1,bottom=B,color=(255/255,171/255,1/255))

x表示x轴的位置,
bottom表示柱子最底端的位置
height表示 柱子的长度
width表示柱子的宽度

029e779c3df972e6c5ceed8e5a08d38f.png

最后我们把 坐标上的线,还有坐标轴上的文字去掉,以及背后画个网格线,

ax.spines['polar'].set_visible(False) #去掉坐标轴的为外面一层 粗的线
plt.grid(color='gray', linestyle=':', linewidth=1,which='major',axis='x',alpha=0.1) #添加网格线
ax.set_yticks([]) #去掉 y轴上的文字
ax.set_xticks(x2) # 应为网格线是跟着x轴走的,如果去掉x轴的话,网格线也就没了
ax.tick_params(axis='x',labelsize=0) #因为我们保留了x轴,x轴上的文字会存在,所以把x轴上的文字大小设置为0

8550555c1ec60d619b6de37bdf439400.png

最后我们选择喜欢的字体,然后打上数据标签,并保存

import matplotlib.font_manager  
font=matplotlib.font_manager.FontProperties(fname='D:FontsEnglishMuseo700-Regular.otf')

for i in range(len(x1)):
    ax.text(x=x1[i],y=y1[i],s=S1[i],color='gray',ha='center', va= 'center',fontsize=12,fontproperties=font)
for i in range(len(x1)):
    ax.text(x=x1[i],y=y2[i],s=S2[i],color='gray',ha='center', va= 'center',fontsize=12,fontproperties=font)
for i in range(len(x1)):
    ax.text(x=x1[i],y=H1[i]+40,s="{}%".format(H1[i]) ,color='gray',ha='center', va= 'center',fontsize=12,fontproperties=font)

fig.savefig('D:test.png',dpi=400,bbox_inches='tight',transparent=False)

裁掉不要的部分

8526344d041dfabe909a5a50ed467faa.png

笔者比较懒惰,就在搞那些文字与标题啦,如果要加文字与标题的话可以保存eps格式的矢量图文件,放在AI里进行深度的加工和处理哦

就这样 完结 撒花✿✿ヽ(°▽°)ノ✿

基础的部分可以看看这个文章:

Mono Lee:Python入门向:Matplotlib自救指南篇,从此做图不求人(一)​zhuanlan.zhihu.com
b8012a8e9078ce39336c5f0a1311d1d4.png

其他在极坐标里的画图可以看看这个

Mono Lee:用Python把图做的好看点:用Matplotlib画个环形图​zhuanlan.zhihu.com
1295510ec4b73ff09d83ac7ce3d470f9.png
Mono Lee:用Python把图做的好看点:用Matplotlib画个玫瑰图​zhuanlan.zhihu.com
a81ceaf4d133b799066cb551fb91e7e4.png
Mono Lee:用Python把图做的好看点:用Matplotlib做个像麦肯锡一样的条形图​zhuanlan.zhihu.com
0f0fba0ec0c5146f809fa27b9ef5cf04.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值