python可视化-pandas一行代码能绘出哪些炫酷图
Posted Python小二
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python可视化-pandas一行代码能绘出哪些炫酷图相关的知识,希望对你有一定的参考价值。
👆点击关注|设为星标|干货速递👆
本文目录
1、单组折线图
2、多组折线图
3、单组条形图
4、多组条形图
5、堆积条形图
6、水平堆积条形图
7、直方图
8、分面直方图
9、箱图
10、面积图
11、堆积面积图
12、散点图
13、单组饼图
14、多组饼图
15、分面图
16、hexbin图
17、andrews_curves图
18、核密度图
19、parallel_coordinates图
20、autocorrelation_plot图
21、radviz图
22、bootstrap_plot图
23、子图(subplot)
24、子图任意排列
25、图中绘制数据表格
27、更多pandas可视化精进资料
pandas可视化主要依赖下面两个函数:
pandas.DataFrame.plot
https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.DataFrame.plot.html?highlight=plot#pandas.DataFrame.plot
pandas.Series.plot
https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.Series.plot.html?highlight=plot#pandas.Series.plot
可绘制下面几种图,注意Dataframe和Series的细微差异:'area', 'bar', 'barh', 'box', 'density', 'hexbin', 'hist', 'kde', 'line', 'pie', 'scatter'导入依赖包
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
from pandas import DataFrame,Series
plt.style.use('dark_background')#设置绘图风格
1、单组折线图
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/74f47/74f4782c92b1ec4b7455d098ac4a62dc5b3fbd9d" alt=""
2、多组折线图
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/dcd19/dcd19712b2116d2e70c6bb4ef98ae9aefa35af5e" alt=""
3、单组条形图
df.iloc[5].plot(kind="bar")
data:image/s3,"s3://crabby-images/fb07a/fb07a035faec5279e8ac511f6316de536b28f890" alt=""
4、多组条形图
df2 = pd.DataFrame(np.random.rand(10, 4), columns=["a", "b", "c", "d"])
df2.plot.bar()
data:image/s3,"s3://crabby-images/586c1/586c14b7a4613dcb419524e1798ab8f83113389e" alt=""
5、堆积条形图
df2.plot.bar(stacked=True)
data:image/s3,"s3://crabby-images/db2c4/db2c48d0722ca9c39d190c626c6ce576c0978d6a" alt=""
6、水平堆积条形图
df2.plot.barh(stacked=True)
data:image/s3,"s3://crabby-images/4a7f9/4a7f9b2b46639088f6457933fc949662c0872258" alt=""
7、直方图
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/9e2a5/9e2a5eabddbc9006a8b8e7818f41a0a82a2c2306" alt=""
8、分面直方图
df.diff().hist(color="r", alpha=0.9, bins=50)
data:image/s3,"s3://crabby-images/a19aa/a19aa8827ce7e4ee04a78be6f87f34790fc1883c" alt=""
9、箱图
df = pd.DataFrame(np.random.rand(10, 5), columns=["A", "B", "C", "D", "E"])
df.plot.box()
data:image/s3,"s3://crabby-images/5e180/5e180e8d5be72c92cf98161420a1f7051a05925c" alt=""
10、面积图
df = pd.DataFrame(np.random.rand(10, 4), columns=["a", "b", "c", "d"])
df.plot.area()
data:image/s3,"s3://crabby-images/07deb/07deb10b43395896f3e78c4b27a72cc8845cb53f" alt=""
11、堆积面积图
df.plot.area(stacked=False)
data:image/s3,"s3://crabby-images/33984/3398434e43183b0209104e9269dfd6f00f5679a2" 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/4ed40/4ed40d66c87248a5ad3d55ddb0e99a0b5839e915" 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/b5da4/b5da4516e25d8b4408eca73443cbf8cf51303570" 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/cc297/cc297f2fee288dc5c034dc70c0d89cb9ecb35c05" 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/48a5c/48a5c4f9a135b34dea71abbb3e219834e626560f" 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/9e110/9e110d0c976040be811bb48242a27ac26d2b7a3e" 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/99027/990275194938ed20b677f36f81af939f1e569df2" alt=""
18、核密度图
ser = pd.Series(np.random.randn(1000))
ser.plot.kde()
data:image/s3,"s3://crabby-images/48a6b/48a6b11546d2b9c21dca22578c87e0a1dd0a1134" 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/955b3/955b3c3061fac2890f004a932224d3750a5f0951" 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/c4bb5/c4bb5632947c80b1f40a7255e8770d0e292c5bad" 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/0c63d/0c63dbc91b285894a6e5cf8315d10263b23426ce" 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/21315/213152098f0b6738100f740a82f9c1d3833d585e" 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/7d437/7d437ace45185601e2cb69a7d2cb96a7d82ed623" alt=""
24、子图任意排列
df.plot(subplots=True, layout=(2, 3), figsize=(6, 6), sharex=False)
data:image/s3,"s3://crabby-images/8ba24/8ba24729bc8b3b15bc36b04db781b0f6e2f00fef" 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/bdca8/bdca888cf2bed7d65955fdd3682645acd4c61cf6" 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/ef63f/ef63f0b7a138fa467c6f9dc08733b4bf30278a71" alt=""
27、更多pandas可视化精进资料
https://pandas.pydata.org/pandas-docs/stable/user_guide/cookbook.html#cookbook-plotting
推荐阅读 点击标题可跳转
以上是关于python可视化-pandas一行代码能绘出哪些炫酷图的主要内容,如果未能解决你的问题,请参考以下文章
数据分析可视化利器:python pandas-profiling 一行代码EDA 探索性数据分析