【Matplotlib】饼图、柱状图、散点图以及三维模型实例

本文介绍了Python数据可视化库Matplotlib的使用,通过四个示例展示了如何创建饼图、柱状图、散点图和三维模型。饼图用于展示各部分比例,柱状图用于比较不同类别的数据,散点图则用于展示两个变量之间的关系,而三维模型则展示了更复杂的可视化能力。每个示例都包含了详细的代码和解释,帮助读者掌握Matplotlib的基本操作。
摘要由CSDN通过智能技术生成
Matplotlib饼图示例
import matplotlib.pyplot as plt

# 构造数据
edu = [0.2515, 0.3724, 0.3336, 0.0368, 0.0057]
labels = ['中专', '大专', '本科', '硕士', '其他']
#设置字体为楷体
plt.rcParams['font.sans-serif'] = ['KaiTi']

# 绘制饼图
plt.pie(x=edu,  # 绘图数据
        labels=labels,  # 添加教育水平标签
        autopct='%.1f%%'  # 设置百分比的格式,这里保留一位小数
        )
plt.show()

在这里插入图片描述

Matplotlib柱状图示例
import matplotlib.pyplot as plt
import numpy as np

k = 10
x = np.arange(k)
y = np.random.rand(k)
plt.bar(x, y)  # 画出 x 和 y 的柱状图

# 增加数值
for x, y in zip(x, y):
    plt.text(x, y, '%.2f' % y, ha='center', va='bottom')
    
# plt.text(x,y,                     x,y:表示坐标值上的值
# 	string,                         string:表示说明文字
# 	fontsize=15,                    fontsize:表示字体大小
# 	verticalalignment="top",        verticalalignment:垂直对齐方式 ,参数:[ ‘center’ | ‘top’ | ‘bottom’ | ‘baseline’ ]
# 	horizontalalignment="right"     horizontalalignment:水平对齐方式 ,参数:[ ‘center’ | ‘right’ | ‘left’ ]
# )

plt.show()

在这里插入图片描述

Matplotlib散点图示例
import matplotlib.pyplot as plt
import numpy as np

k = 500
x = np.random.rand(k)
print(x)
y = np.random.rand(k)
print(y)
size = np.random.rand(k) * 50  # 生成每个点的大小
print(size)
colour = np.arctan2(x, y)  # 生成每个点的颜色大小
# np.arctan2(y,x)是表示X-Y平面上所对应的(x,y)坐标的角度,它的值域范围是(-Pi,Pi) 用数学表示就是:arctan2(y,x)=arcta(y/x)-Pi 当y<0时,其值为负,当y>0时,其值为正
plt.scatter(x, y, s=size, c=colour)  # 生成散点图

plt.colorbar()  # 添加颜色栏
plt.show()

在这里插入图片描述

Matplotlib三维模型示例
import matplotlib.pyplot as plt
import numpy as np
from matplotlib import cm

fig = plt.figure(num=None, figsize=None, dpi=None, facecolor=None, edgecolor=None, frameon=True)
# num:图像编号或名称,数字为编号 ,字符串为名称
# figsize:指定figure的宽和高,单位为英寸;
# dpi参数指定绘图对象的分辨率,即每英寸多少个像素,缺省值为80      1英寸等于2.5cm,A4纸是 21*30cm的纸张
# facecolor:背景颜色
# edgecolor:边框颜色
# frameon:是否显示边框

ax = fig.add_subplot(111, projection='3d')

u = np.linspace(-1, 1, 100)
x, y = np.meshgrid(u, u)  # 生成网格点坐标矩阵。
print(x,y)
z = x ** 2 + y ** 2

ax.plot_surface(x, y, z, rstride=4, cstride=4, cmap=cm.YlGnBu_r)
plt.show()

在这里插入图片描述

### 回答1: 要使用Python绘制三维饼图,需要使用matplotlib库中的mplot3d模块。下面是一个示例代码: ```python import matplotlib.pyplot as plt # 数据 sizes = [15, 30, 45, 10] labels = ['A', 'B', 'C', 'D'] colors = ['red', 'blue', 'green', 'yellow'] # 创建子图 fig = plt.figure() ax = fig.add_subplot(111, projection='3d') # 绘制饼图 ax.pie(sizes, labels=labels, colors=colors, autopct='%1.1f%%', startangle=90) # 设置坐标轴刻度以避免比例失调 ax.set_xlim(-1, 1) ax.set_ylim(-1, 1) ax.set_zlim(0, 1) # 添加图例 ax.legend(labels) # 显示图形 plt.show() ``` 在这个示例中,我们使用`sizes`列表存储每个部分的大小,`labels`列表存储每个部分的标签,`colors`列表存储每个部分的颜色。我们使用`ax.pie`函数来绘制饼图,其中`autopct='%1.1f%%'`用于在饼图中显示具体的百分比值,`startangle=90`设置起始角度为90度。 然后,我们通过设置坐标轴刻度使用`ax.set_xlim`、`ax.set_ylim`和`ax.set_zlim`来避免比例失调。 最后,通过调用`ax.legend`函数来添加图例,并使用`plt.show`显示图形。运行这段代码将绘制出一个简单的三维饼图。 ### 回答2: 要用Python三维饼图,可以使用matplotlib库中的mplot3d模块。首先,需要安装matplotlib库,并在代码中导入所需的模块。接下来,创建一个figure对象,并添加一个子图,设置投影为3D。然后,使用axes的pie方法创建一个饼图,并设置图例、阴影效果等属性。最后,调用show方法显示饼图。 下面是一个简单的示例代码: ``` import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import axes3d # 创建figure对象和3D子图 fig = plt.figure() ax = fig.add_subplot(111, projection='3d') # 饼图的数据 sizes = [15, 30, 45, 10] labels = ['A', 'B', 'C', 'D'] colors = ['red', 'blue', 'green', 'yellow'] # 创建饼图 ax.pie(sizes, labels=labels, colors=colors, shadow=True) # 设置图例 ax.legend(labels, loc='upper right') # 设置坐标轴标签 ax.set_xlabel('X Label') ax.set_ylabel('Y Label') ax.set_zlabel('Z Label') # 显示饼图 plt.show() ``` 这段代码会创建一个简单的三维饼图,其中sizes定义了每个扇区的大小,labels定义了每个扇区的标签,colors定义了每个扇区的颜色。你可以根据自己的需求修改这些数据。另外,还可以调整其他属性,如图例的位置、坐标轴的标签等,以满足你的需求。 ### 回答3: 要使用Python绘制三维饼图,我们可以使用matplotlib库的mplot3d子库来实现。下面是一个简单的例子: 首先,我们需要导入需要的库: ```python import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D ``` 然后,创建一个3D图形对象: ```python fig = plt.figure() ax = fig.add_subplot(111, projection='3d') ``` 接下来,定义饼图的数据和标签: ```python sizes = [15, 30, 45, 10] labels = ['A', 'B', 'C', 'D'] ``` 然后,使用ax.pie()绘制饼图: ```python ax.pie(sizes, labels=labels, autopct='%1.1f%%') ``` 最后,将图形显示出来: ```python plt.show() ``` 完整的代码如下所示: ```python import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D fig = plt.figure() ax = fig.add_subplot(111, projection='3d') sizes = [15, 30, 45, 10] labels = ['A', 'B', 'C', 'D'] ax.pie(sizes, labels=labels, autopct='%1.1f%%') plt.show() ``` 运行代码后,将会显示一个三维饼图,其中每个扇形的大小表示对应标签所占份额。 需要注意的是,绘制三维饼图时,由于透视关系,可能会导致扇形形状略有变形,所以使用时需注意观察和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Koma_zhe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值