导入package
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
import pandas as pd
散点图
N = 1000
x = np.random.randn(N)
y = np.random.randn(N)
# matplotlib
plt.scatter(x,y,marker='x')
plt.show()
#seaborn
df = pd.DataFrame({'x':x,'y':y})
sns.jointplot(x="x",y="y",data=df,kind='scatter');
plt.show()
data:image/s3,"s3://crabby-images/7727b/7727b51bb3289cd35914502e5707051b83f1ef8a" alt=""
data:image/s3,"s3://crabby-images/ac7c2/ac7c2bb2d1efaf4c37069bced0829225a2c68897" alt=""
折线图
x = [2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019]
y = [5, 3, 6, 20, 17, 16, 19, 30, 32, 35]
# matplotlib
plt.plot(x,y)
plt.show()
#seaborn
df = pd.DataFrame({'x':x,'y':y})
sns.lineplot(x="x",y="y",data=df)
plt.show()
data:image/s3,"s3://crabby-images/6127f/6127fb3e8a5fb717ff8074002381a3b19f577927" alt=""
data:image/s3,"s3://crabby-images/f9858/f985831a9e16118cd6434dc1523a5c05365306cb" alt=""
直方图
a = np.random.rand(100)
s = pd.Series(a)
#matplotlib
plt.hist(s)
plt.show()
#seaborn
sns.distplot(s,kde=False)
plt.show()
sns.distplot(s,kde=True)
plt.show()
data:image/s3,"s3://crabby-images/8dda2/8dda25ef75089850493bb681adefc8dea145322d" alt=""
data:image/s3,"s3://crabby-images/5cdd9/5cdd9081c16c6f58f77e263aa949dd72a7377a1d" alt=""
data:image/s3,"s3://crabby-images/d97eb/d97eb0550f638ad732092f5255e0ae408878bfd3" alt=""
条形图
x = ['Cat1', 'Cat2', 'Cat3', 'Cat4', 'Cat5']
y = [5, 4, 8, 12, 7]
# matplotlib
plt.bar(x,y)
plt.show()
# seaborn
sns.barplot(x,y)
plt.show()
data:image/s3,"s3://crabby-images/f535d/f535db5aca63d4c16d714d6cc020306b9ee91c6a" alt=""
data:image/s3,"s3://crabby-images/99798/99798f5953b1c01b13fa229e669ccb94b0d60b40" alt=""
箱线图
data = np.random.normal(size=(10,4))
labels = ['A','B','C','D']
# matplotlib
plt.boxplot(data,labels=labels)
plt.show()
# seaborn
df = pd.DataFrame(data,columns=labels)
sns.boxplot(data=df)
plt.show()
data:image/s3,"s3://crabby-images/d30c7/d30c7f1f583c6c993c148908c9a1e8e7dc0a37be" alt=""
data:image/s3,"s3://crabby-images/bc060/bc06004706b8ee363e2731a6d46660d2147dc194" alt=""
扇形图
nums = [25, 37, 33, 37, 6]
labels = ['High-school','Bachelor','Master','Ph.d', 'Others']
# matplotlib
plt.pie(x=nums,labels=labels)
plt.show()
data:image/s3,"s3://crabby-images/84fca/84fcaf2eda761992c98c385cf112532fadf4d016" alt=""
热图
flights = sns.load_dataset('flights')
data = flights.pivot('year','month','passengers')
# seaborn
sns.heatmap(data)
plt.show()
data:image/s3,"s3://crabby-images/13bb4/13bb418aaec8b8c4672b68d2499e59358e4e8714" alt=""
蜘蛛图
from matplotlib.font_manager import FontProperties
labels=np.array([u" 推进 ","KDA",u" 生存 ",u" 团战 ",u" 发育 ",u" 输出 "])
stats=[83, 61, 95, 67, 76, 88]
angles = np.linspace(0,2*np.pi,len(labels),endpoint=False)
stats = np.concatenate((stats,[stats[0]]))
angles = np.concatenate((angles,[angles[0]]))
# matplotlib
fig = plt.figure()
ax = fig.add_subplot(111,polar=True)
ax.plot(angles,stats,'o-',linewidth=2)
ax.fill(angles,stats,alpha=0.25)
# chinese
# font = FontProperties()
# ax.set_thetagrids(angles*180/np.pi,labels,FontProperties=font)
ax.set_thetagrids(angles*180/np.pi,labels)
plt.show()
data:image/s3,"s3://crabby-images/d3b75/d3b7525240f7a927418069b2b1b8f398f86b39b5" alt=""
二元变量分布
tips = sns.load_dataset("tips")
print(tips.head(10))
# seaborn
sns.jointplot(x='total_bill',y='tip',data=tips,kind='scatter')
sns.jointplot(x='total_bill',y='tip',data=tips,kind='kde')
sns.jointplot(x='total_bill',y='tip',data=tips,kind='hex')
plt.show()
成对关系
iris = sns.load_dataset('iris')
# seaborn
sns.pairplot(iris)
plt.show()
网友评论