Pandas一行代码绘制25种美图
data:image/s3,"s3://crabby-images/14ac2/14ac2b05b6d20459e755cc7a4d803706fab9e431" alt=""
导读:今天介绍一下,如何用Pandas的一行代码绘制 25 种美图。
data:image/s3,"s3://crabby-images/bbcb3/bbcb3797089fc054f8ebbc2b1678295291676e6c" alt=""
单组折线图、多组折线图、单组条形图、多组条形图、堆积条形图、水平堆积条形图、直方图、分面直方图、箱图、面积图、堆积面积图、散点图、单组饼图、多组饼图、分面图、hexbin图、andrews_curves图、核密度图、parallel_coordinates图、autocorrelation_plot图、radviz图、bootstrap_plot图、子图(subplot)、子图任意排列、图中绘制数据表格
pandas.DataFrame.plot
pandas.Series.plot
data:image/s3,"s3://crabby-images/1f604/1f604fd55c351c93e6f19a91e6308f2ad4edfa05" alt=""
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
from pandas import DataFrame,Series
plt.style.use('dark_background')#设置绘图风格
np.random.seed(0)#使得每次生成的随机数相同
ts = pd.Series(np.random.randn(1000), index=pd.date_range("1/1/2000", periods=1000))
ts1 = ts.cumsum()#累加
ts1.plot(kind="line")#默认绘制折线图
data:image/s3,"s3://crabby-images/d8d80/d8d807ac7804d9134411867d086016cc1937d339" alt=""
np.random.seed(0)
df = pd.DataFrame(np.random.randn(1000, 4), index=ts.index, columns=list("ABCD"))
df = df.cumsum()
df.plot()#默认绘制折线图
data:image/s3,"s3://crabby-images/398db/398dbb17c1f36dcf274589e8d385ff2a3d2ae254" alt=""
df.iloc[5].plot(kind="bar")
data:image/s3,"s3://crabby-images/e5126/e51267b5becc234058bc8afae9d400e448899596" alt=""
df2 = pd.DataFrame(np.random.rand(10, 4), columns=["a", "b", "c", "d"])
df2.plot.bar()
data:image/s3,"s3://crabby-images/99d57/99d5737ac71553a043d83bfdffc898d73ba98b11" alt=""
05 堆积条形图
df2.plot.bar(stacked=True)
data:image/s3,"s3://crabby-images/1db3a/1db3a854d0104a0736d70e91706cb349d26455e3" alt=""
06 水平堆积条形图
df2.plot.barh(stacked=True)
data:image/s3,"s3://crabby-images/e9dd0/e9dd0b7f2240da3c02fd7dbe815d755b92561b0a" alt=""
07 直方图
df4 = pd.DataFrame(
{
"a": np.random.randn(1000) + 1,
"b": np.random.randn(1000),
"c": np.random.randn(1000) - 1,
},
columns=["a", "b", "c"],
)
df4.plot.hist(alpha=0.8)
data:image/s3,"s3://crabby-images/c63ee/c63ee193562cba0dec8ef1429efa717061fbb715" alt=""
08 分面直方图
df.diff().hist(color="r", alpha=0.9, bins=50)
data:image/s3,"s3://crabby-images/9f957/9f957ca447be7fbbefc340383983a47cbf0d757d" alt=""
09 箱图
df = pd.DataFrame(np.random.rand(10, 5), columns=["A", "B", "C", "D", "E"])
df.plot.box()
data:image/s3,"s3://crabby-images/789c9/789c91421d0ba4100509e4191b536552ec6e9bc7" alt=""
10 面积图
df = pd.DataFrame(np.random.rand(10, 4), columns=["a", "b", "c", "d"])
df.plot.area()
data:image/s3,"s3://crabby-images/c6426/c6426aa1e4d374176a376d4deb28d4ae8e59e577" alt=""
11 堆积面积图
df.plot.area(stacked=False)
data:image/s3,"s3://crabby-images/8093d/8093d4488eb5605d60a9c13bc4a96985a62f86ea" alt=""
12 散点图
ax = df.plot.scatter(x="a", y="b", color="r", label="Group 1",s=90)
df.plot.scatter(x="c", y="d", color="g", label="Group 2", ax=ax,s=90)
data:image/s3,"s3://crabby-images/3cbe9/3cbe93798b381edb3d93fa1c6d71d67cb5e06875" alt=""
13 单组饼图
series = pd.Series(3 * np.random.rand(4), index=["a", "b", "c", "d"], name="series")
series.plot.pie(figsize=(6, 6))
data:image/s3,"s3://crabby-images/8c2b5/8c2b51ecae4da8c9576380e80d4e7670b047edbe" alt=""
14 多组饼图
df = pd.DataFrame(
3 * np.random.rand(4, 2), index=["a", "b", "c", "d"], columns=["x", "y"]
)
df.plot.pie(subplots=True, figsize=(8, 4))
data:image/s3,"s3://crabby-images/0e6c5/0e6c54dc1f40740e11f4c618e930ead259869a97" alt=""
15 分面图
import matplotlib as mpl
mpl.rc_file_defaults()
plt.style.use('fivethirtyeight')
from pandas.plotting import scatter_matrix
df = pd.DataFrame(np.random.randn(1000, 4), columns=["a", "b", "c", "d"])
scatter_matrix(df, alpha=0.2, figsize=(6, 6), diagonal="kde")
plt.show()
data:image/s3,"s3://crabby-images/7b3ad/7b3adebf75a3024f916f398f42c092f260658413" alt=""
16 hexbin图
df = pd.DataFrame(np.random.randn(1000, 2), columns=["a", "b"])
df["b"] = df["b"] + np.arange(1000)
df.plot.hexbin(x="a", y="b", gridsize=25)
data:image/s3,"s3://crabby-images/bbcb3/bbcb3797089fc054f8ebbc2b1678295291676e6c" alt=""
17 andrews_curves图
from pandas.plotting import andrews_curves
mpl.rc_file_defaults()
data = pd.read_csv("iris.data.txt")
plt.style.use('dark_background')
andrews_curves(data, "Name")
data:image/s3,"s3://crabby-images/396c4/396c44b81329692fd779a3c24daed507985de52c" alt=""
18 核密度图
ser = pd.Series(np.random.randn(1000))
ser.plot.kde()
data:image/s3,"s3://crabby-images/95455/95455a0b4f41f705975020dcdf69ee485e09c730" alt=""
19 parallel_coordinates图
from pandas.plotting import parallel_coordinates
data = pd.read_csv("iris.data.txt")
plt.figure()
parallel_coordinates(data, "Name")
data:image/s3,"s3://crabby-images/a1bea/a1bea9cb0be83569365f3e178d1c1775974a2964" alt=""
20 autocorrelation_plot图
from pandas.plotting import autocorrelation_plot
plt.figure();
spacing = np.linspace(-9 * np.pi, 9 * np.pi, num=1000)
data = pd.Series(0.7 * np.random.rand(1000) + 0.3 * np.sin(spacing))
autocorrelation_plot(data)
data:image/s3,"s3://crabby-images/044fe/044fe1fd677330864b655df0f82dd8d14de08ba1" alt=""
21 radviz图
from pandas.plotting import radviz
data = pd.read_csv("iris.data.txt")
plt.figure()
radviz(data, "Name")
data:image/s3,"s3://crabby-images/15be1/15be1c307f54d5b70d8012860e787e2cc978d61c" alt=""
22 bootstrap_plot图
from pandas.plotting import bootstrap_plot
data = pd.Series(np.random.rand(1000))
bootstrap_plot(data, size=50, samples=500, color="grey")
data:image/s3,"s3://crabby-images/759b9/759b96b03d0ffa42249d983ceeb8994f21cb15da" alt=""
23 子图(subplot)
df = pd.DataFrame(np.random.randn(1000, 4), index=ts.index, columns=list("ABCD"))
df.plot(subplots=True, figsize=(6, 6))
data:image/s3,"s3://crabby-images/b04a9/b04a95b71d3f1dd50e428f972cefca4ed1674dd4" alt=""
24 子图任意排列
df.plot(subplots=True, layout=(2, 3), figsize=(6, 6), sharex=False)
data:image/s3,"s3://crabby-images/68042/680424b9571559dd3ec16a0069858b86cd9b24e9" alt=""
fig, axes = plt.subplots(4, 4, figsize=(9, 9))
plt.subplots_adjust(wspace=0.5, hspace=0.5)
target1 = [axes[0][0], axes[1][1], axes[2][2], axes[3][3]]
target2 = [axes[3][0], axes[2][1], axes[1][2], axes[0][3]]
df.plot(subplots=True, ax=target1, legend=False, sharex=False, sharey=False);
(-df).plot(subplots=True, ax=target2, legend=False, sharex=False, sharey=False)
data:image/s3,"s3://crabby-images/93385/93385fe3780e622de50de1bb71a114f720c5b19e" alt=""
25 图中绘制数据表格
from pandas.plotting import table
mpl.rc_file_defaults()
#plt.style.use('dark_background')
fig, ax = plt.subplots(1, 1)
table(ax, np.round(df.describe(), 2), loc="upper right", colWidths=[0.2, 0.2, 0.2]);
df.plot(ax=ax, ylim=(0, 2), legend=None);
data:image/s3,"s3://crabby-images/9d69d/9d69dac83af12dc21ba47b71830e6b796e473d5c" alt=""
data:image/s3,"s3://crabby-images/be366/be366839bbd20cf91654966011aa5845cb4fe8b4" alt="音符"
data:image/s3,"s3://crabby-images/2d111/2d11151a2e0e5f0a09070e227876c5133ce6d81f" alt=""
评论