主要是Seaborn常见的操作
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
def sinplot(flip=1):
x = np.linspace(0, 14, 100)
for i in range(1, 7):
plt.plot(x, np.sin(x + i * .5) * (7 - i) * flip)
# 5种 主题风格
# darkgrid
# whitegrid
# dark
# white
# ticks
# sns.set()
# sinplot()
# sns.set_style('whitegrid')
data = np.random.normal(size=(20, 6)) + np.arange(6) / 2
#
# sns.boxplot(data = data)
# sns中 ticks 风格, 可以把上面和右边刻度去掉
# sns.set_style('ticks')
# sinplot()
# sns.despine()
# 设置离x轴的距离
# sns.violinplot(data)
# sns.despine(offset=30)
# 保留x轴或者y轴
# sns.set_style('whitegrid')
# data = np.random.normal(size=(20, 6)) + np.arange(6) / 2
# sns.boxplot(data = data, palette='deep')
# sns.despine(left=True)
# 指定风格, 可以使用with
# with sns.axes_style('darkgrid'):
# plt.subplot(211)
# sinplot()
# plt.subplot(212)
# sinplot(-1)
# 大小风格
# sns.set()
# sns.set_context('paper')
# plt.figure(figsize=(8, 6))
# sinplot()
# sns.set()
# sns.set_context('talk')
# plt.figure(figsize=(8, 6))
# sinplot()
#
# sns.set()
# sns.set_context('poster')
# plt.figure(figsize=(8, 6))
# sinplot()
# font_scale 字体 后面是线条
sns.set_context('notebook', font_scale=1.5, rc={'lines.linewidth': 4.5})
sinplot()
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
sns.set(rc={'figure.figsize': (6, 6)})
sns.palplot(sns.color_palette('Paired', 10))
import seaborn as sns
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from scipy import stats, integrate
sns.set(color_codes=True)
np.random.seed(sum(map(ord, 'distributions')))
# iris = sns.load_dataset('iris')
# sns.pairplot(iris)
# 回归分析绘图
import seaborn as sns
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
sns.set(color_codes=True)
np.random.seed(sum(map(ord, 'distributions')))
titanic = sns.load_dataset('titanic')
iris = sns.load_dataset('iris')
tips = pd.read_csv('tips.csv', delimiter='\t')
# sns.stripplot(x='day', y='total_bill', data=tips)
# 如果数据量过大,加上参数
# sns.stripplot(x='day', y='total_bill', data=tips, jitter=True)
# sns.swarmplot(x='day', y='total_bill', data=tips)
# 加上属性值
# sns.swarmplot(x='day', y='total_bill', data=tips, hue='sex')
# sns.swarmplot(x='day', y='total_bill', data=tips, hue='time')
# 盒图
# sns.boxplot(x='day', y='total_bill', data=tips, hue='time')
# 小提琴图
# sns.violinplot(x='day', y='total_bill', data=tips, hue='time')
# sns.violinplot(x='day', y='total_bill', data=tips, hue='time', split=True)
# 显示值的集中趋势
# sns.boxplot(x='sex', y='survived', hue='class', data=titanic)
# 点图可以更好的描述变化差异
# sns.pointplot(x='sex', y='survived', hue='class', data=titanic)
# sns.pointplot(x='class', y='survived', hue='sex', data=titanic, palette={'male': 'g', 'female':'m'},
# markers=["^", "o"], linestyles=['-', '--'])
# 宽性数据
# sns.boxplot(data=iris, orient='h')
# 多层面板分类图
# sns.factorplot(x='day', y='total_bill', hue='smoker', data=tips)
# sns.factorplot(x='day', y='total_bill', hue='smoker', data=tips, kind='swarm')
# sns.factorplot(x='day', y='total_bill', hue='smoker', data=tips, kind='bar')
import seaborn as sns
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
sns.set(color_codes=True)
np.random.seed(sum(map(ord, 'distributions')))
titanic = sns.load_dataset('titanic')
iris = sns.load_dataset('iris')
tips = pd.read_csv('tips.csv', sep='\t')
print(tips.head())
# g = sns.FacetGrid(tips, col='time')
# g.map(plt.hist, 'tip')
# g = sns.FacetGrid(tips, col='sex', hue='smoker')
# g.map(plt.scatter, 'total_bill', 'tip', alpha=.7)
# g.add_legend()
# g = sns.FacetGrid(tips, row='smoker', col='time', margin_titles=True)
# g.map(sns.regplot, 'size', 'total_bill', color='.3', fit_reg=False, x_jitter=.1)
# g = sns.FacetGrid(tips, col='day', size=4, aspect=.5)
# g.map(sns.barplot, 'sex', 'total_bill')
# from pandas import Categorical
# ordered_days = tips.day.value_counts().index
# print(ordered_days)
# ordered_days = Categorical(['Thur', 'Fri','Sat', 'Sun'])
# print(ordered_days)
#
# g.map(sns.boxplot, 'total_bill')
# 使用FaceGrid 绘制多变量
# pal = dict(Lunch = 'seagreen', Dinner='gray')
# g = sns.FacetGrid(tips, hue='time', palette=pal, size=5)
# g.map(plt.scatter, 'total_bill', 'tip', s=50, alpha=.7, linewidth=.5, edgecolor='white')
# g.add_legend()
# g = sns.FacetGrid(tips, hue='sex', palette='Set1', size=5, hue_kws={'marker': ['^', 'v']})
# g.map(plt.scatter, 'total_bill', 'tip', s=100, linewidth=.5, edgecolor='white')
# g.add_legend()
# 改变x轴和y轴的坐标
# with sns.axes_style('white'):
# g = sns.FacetGrid(tips, row='sex', col='smoker', margin_titles=True, size=2.5)
# g.map(plt.scatter, 'total_bill', 'tip', color='#334488', edgecolor='white', lw=.5)
# g.set_axis_labels('Total bill US Dollars', 'Tip')
# g.set(xticks=[10, 30, 50], yticks=[2, 6, 10])
# g.fig.subplots_adjust(wspace=.02, hspace=.02)
# 对图
iris = sns.load_dataset('iris')
# g = sns.PairGrid(iris)
# g.map(plt.scatter)
# 对角线上画图
# g = sns.PairGrid(iris, hue='species')
# g.map_diag(plt.hist)
# g.map_offdiag(plt.scatter)
# g.add_legend()
# 画部分特征
# print(iris)
# g = sns.PairGrid(iris, vars=['sepal_length', 'sepal_width'], hue='species')
# g.map(plt.scatter)
# 加上颜色
g = sns.PairGrid(tips, hue='size', palette='GnBu_d')
g.map(sns.scatterplot, s=50, edgecolor='white')
g.add_legend()
import seaborn as sns
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
sns.set()
np.random.seed(0)
uniform_data = np.random.rand(3, 3)
print(uniform_data)
flights = pd.read_csv('flights.csv')
print(flights.head())
flights = flights.pivot('month', 'year', 'passengers')
print(flights)
ax = sns.heatmap(flights, cbar=False)
plt.show()
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
· 如何打造一个高并发系统?