官方教程:http://pyecharts.herokuapp.com/
pyecharts 是一个用于生成 Echarts 图表的类库。Echarts 是百度开源的一个数据可视化 JS 库。用 Echarts 生成的图可视化效果非常棒,为了与 Python 进行对接,方便在 Python 中直接使用数据生成图。
from pyecharts import Chart,configure #导入所需绘图函数configure(output_image=True) #可以将图表保存为svg/jpeg/png/pdf/gif chart = Chart('主标题','副标题') #Chart是我们绘图函数attr = ['x1','x2','x3','x4'] #attr是属性,也就是常见的X轴标签v = [y1,y2,y3,y4] #v是各个属性对应的值,也就是常见的Y值chart.use_theme() #设置图表主题 chart.add('图标',attr,v1) #add画图图层,添加我们所需的参数chart.render(path = '***.jpeg') #图表输出,path是输出路径
render会默认将图表输出为html格式,可在浏览器打开。但是想要插入到ppt当中,清晰度会下降,因此需要将其转化为其他格式,如svg/jpeg/png/pdf/gif 等等。要实现格式的转换,需要安装:
代码
import matplotlib.pyplot as pltplt.rc('font',family='Times New Roman') #准备数据data = [0.16881,0.14966,0.07471,0.06992,0.04762,0.03541,0.02925,0.02411,0.02316,0.01409,0.36326]#准备标签labels = ['Java','C','C++','Python','Visual Basic.NET','C#','PHP','JavaScript','SQL','Assembly langugage','其他']#将排列在第4位的语言(Python)分离出来explode =[0,0,0,0.3,0,0,0,0,0,0,0]#使用自定义颜色colors = ['red','pink','magenta','purple','orange']#将横、纵坐标轴标准化处理,保证饼图是一个正圆,否则为椭圆plt.axes(aspect='equal')#控制X轴和Y轴的范围(用于控制饼图的圆心、半径)plt.xlim(0,8)plt.ylim(0,8)#不显示边框plt.gca().spines['right'].set_color('none')plt.gca().spines['top'].set_color('none')plt.gca().spines['left'].set_color('none')plt.gca().spines['bottom'].set_color('none')#绘制饼图plt.pie(x=data, labels=labels,explode=explode,colors=colors, autopct='%.3f%%', pctdistance=0.8, labeldistance=1.0, startangle=180, center=(4,4), radius=3.8, counterclock= False,) #不显示X轴、Y轴的刻度值plt.xticks(())plt.yticks(())#添加图形标题plt.title('2020年4月的编程语言指数排行榜',fontproperties=my_font)#显示图形plt.show()from pyecharts import options as optsfrom pyecharts.charts import Map#数据a1 = ['广东', '山东', '河南', '四川', '江苏', '河北', '湖南', '安徽', '湖北', '浙江', '广西', '云南', '江西', '辽宁', '黑龙江', '陕西', '山西', '福建', '贵州', '重庆', '吉林', '甘肃', '内蒙古', '台湾', '上海', '新疆', '北京', '天津', '海南', '香港', '宁夏', '青海', '西藏', '澳门']a2 = [10430.03, 9579.31, 9402.36, 8041.82, 7865.99, 7185.42, 6568.37, 5950.1, 5723.77, 5442.0, 4602.66, 4596.6, 4456.74, 4374.63, 3831.22, 3732.74, 3571.21, 3552.0, 3476.65, 2884.0, 2746.22, 2557.53, 2470.63, 2316.2, 2301.391, 2181.33, 1961.2, 1293.82, 867.15, 709.76, 630.14, 562.67, 300.21, 55.23]def map_visualmap(): c = ( Map() .add("人口分布数据地图", [list(i) for i in zip(a1,a2)], "china") .set_global_opts( title_opts=opts.TitleOpts(), visualmap_opts=opts.VisualMapOpts(max_= max(a2),min_=min(a2)), ) ) return cif __name__ == '__main__': city_ = map_visualmap() city_.render(path="DataMap_test.html")