当前位置: 首页 > news >正文

网站弄好了怎么推广域名查询阿里云

网站弄好了怎么推广,域名查询阿里云,wordpress 刷单,wordpress页面无法评论Seaborn 简介 Seaborn 是一个基于 Matplotlib 的图形可视化 Python 库,提供了高度交互式的接口,使用户能够轻松绘制各种吸引人的统计图表。Seaborn 可以直接使用 Pandas 的 DataFrame 和 Series 数据进行绘图。 1. Seaborn 绘制单变量图 (1) 直方图 h…

Seaborn 简介

Seaborn 是一个基于 Matplotlib 的图形可视化 Python 库,提供了高度交互式的接口,使用户能够轻松绘制各种吸引人的统计图表。Seaborn 可以直接使用 Pandas 的 DataFrame 和 Series 数据进行绘图。

1. Seaborn 绘制单变量图

(1) 直方图 histplot

  • hue: 根据另一个分类变量对数据进行分组并显示不同颜色的直方图。

  • kde: 是否绘制核密度估计曲线。

  • 其他常用参数:

    • bins: 控制直方图的条数。
    • stat: 选择统计方式(如 density 或 count)。

    示例代码:

import seaborn as sns
import matplotlib.pyplot as plt# fig 画布对象, ax坐标轴对象
fig, ax = plt.subplots(figsize=(10, 5))
# todo data: 要操作的 df或Series对象
# todo x, y: x轴 和 y轴 数据
# todo bins: 直方图, 划分区间的个数
# todo hue: 分组字段, 默认为None, 会按照该字段分组, 把相同分组数据画到一张图上
# todo kde: 绘制 核密度预估曲线
sns.histplot(data=tips, x='total_bill', bins=10, hue='sex', kde=True)
ax.set_title('直方图-总消费金额分布情况')
plt.show()

(2) 密度图 kdeplot

  • X 轴: 样本数据。
  • Y 轴: 密度值。
  • fill: 是否填充曲线下方区域。
  • 其他常用参数:
    • bw_adjust: 调整带宽以控制平滑度。

示例代码:

# todo 密度图是连续的 -> 概率分布   直方图是离散的 -> 样本数据
# todo 应用场景: 基于少量的样本数据, 去推理 总体数据的概率分布情况fig, ax = plt.subplots(figsize=(10, 5))
sns.kdeplot(data=tips, x='total_bill')
ax.set_title('密度图-总消费金额分布情况')
plt.show()

(3) 计数图 countplot

  • color: 仅支持单一颜色。
  • hue: 可用来在每个条形中分组显示不同的类别。
  • 其他常用参数:
    • order: 控制条形图中类别的顺序。

示例代码:

# todo 计数图 = 按照某个字段分组, 统计每个分组的数量, 然后绘制成 条形图(柱状图)
# 按照 星期分组, 统计每个星期的 消费次数
# 方式一
fig, ax = plt.subplots(figsize=(10, 5))
sns.countplot(data=tips, x='day', color='b')
ax.set_title('消费次数分布情况')
plt.show()# 方式二: 手动分组 + 聚合计算
tips.day.value_counts().plot.bar(figsize=(10, 5), color=['red', 'blue', 'yellow'])
ax.set_title('消费次数分布情况')
plt.show()

2. Seaborn 双变量数据可视化

(1) 散点图 scatterplot

  • hue: 根据另一变量划分颜色。(分组字段)

  • size: 根据另一变量划分点的大小。

  • 其他常用参数:

  • style: 根据另一变量改变点的形状。

示例代码:

# hue: 分组字段
fig, ax = plt.subplots(figsize=(10, 5))
# 2. 绘制散点图, 分析: 总消费金额, 小费 之间的关系.
# sns.scatterplot(data=tips, x='total_bill', y='tip')
sns.scatterplot(data=tips, x='total_bill', y='tip', hue='sex')
ax.set_title('散点图-总消费金额和消费之间的关系')
plt.show()

(2) 回归图 regplot

  • fit_reg: 默认绘制线性拟合回归线,设为 False 可禁用。

  • 其他常用参数:

  • ci: 置信区间的大小。

示例代码:

fig, ax = plt.subplots(figsize=(10, 5))
# todo fit_reg: 是否绘制回归线, 默认为 True
# todo 拟合回归线: 基于数据点(散点), 拟合出一条直线, 底层运行: 线性回归
sns.regplot(data=tips, x='total_bill', y='tip', fit_reg=True)
# sns.regplot(data=tips, x='total_bill', y='tip', fit_reg=False)
ax.set_title('散点图-总消费金额和消费之间的关系')
plt.show()

(3) 联合图 jointplot

一些函数在绘图的时候, 是直接绘制的, 无需指定画板, 也没有 figsize属性设置(图形宽高), 但一般有 height属性, 设置图形宽高: 如 jointplot, 可以把 jointplot()理解为: 散点图 + 直方图(每行每列都会绘制直方图)
  • kind: 绘制的图的类型(如 scatter, kde(密度图), hex(蜂巢图))。

  • height: 图的高度。

  • 其他常用参数:

  • hue: 分组显示不同的类别。

示例代码:

sns.jointplot(data=tips, x='total_bill', y='tip', kind='scatter', height=8)
plt.title('Jointplot of Total Bill and Tip')
plt.show()

(4) 2D 密度图 kdeplot

  • fill: 填充密度图。

  • cbar: 显示颜色区间图例。

  • 其他常用参数:

  • levels: 指定绘制的等高线的数量。

示例代码:

# 1. 获取 画布, 坐标轴对象
fig, ax = plt.subplots(figsize=(10, 5))
# 2. 设置2D密度图
# todo cbar: 是否绘制颜色条    fill: 是否填充颜色
sns.kdeplot(data=tips, x='total_bill', y='tip', fill=True, cbar=True)
ax.set_title('2D Ked TotalBill & Tip')
plt.show()

(5) 箱线图 boxplot

  • 定义: 显示数据的分位数及异常值。

  • 组成部分: 包括上边缘、上四分位数、中位数、下四分位数、下边缘、异常值。

  • 其他常用参数:

  • hue: 根据分类变量分组显示箱线。

  • 箱子的中间有一条线,代表了数据的中位数

  • 箱子的上下底,分别是数据的上四分位数(Q3)和下四分位数(Q1)

  • 箱体包含了50%的数据。因此,箱子的高度在一定程度上反映了数据的波动程度

  • 上下边缘则代表了该组数据的最大值和最小值

    • IQR = 上四分位数(Q3) - 下四分位数(Q1)

      四分位距(interquartile range, IQR),又称四分差

    • 判断异常值时最大值 = 上四分位数(Q3) + 1.5 IQR 大于这个值的就是异常值

    • 判断异常值时最小值 = 下四分位数(Q1)- 1.5 IQR 小于这个值的就是异常值

  • 有时候箱子外部会有一些点,可以理解为数据中的“异常值”

示例代码:

# 需求: 通过 箱线图(盒须图, 箱子图), 分析: 总消费金额, 时间 之间的关系.
# todo IQR = Q3 - Q1 : InterquantileRange四分位距表示法
fig, ax = plt.subplots(figsize=(10, 5))
sns.boxplot(data=tips, x='time', y='total_bill')
ax.set_title('箱线图-分析就餐时间和消费总金额之间的关系0')
plt.show()

(6) 小提琴图 violinplot

小提琴图, 它是经典的可视化方法,但可能会掩盖数据的分布

小提琴图能显示与箱线图相同的值, 小提琴图把"箱线"绘成核密度估计,

有助于保留数据的更多可视化信息

  • 优势
    • 小提琴图同时展示了数据的统计分布和概率密度,能够更好地揭示数据的形态和特征。
    • 小提琴图可以通过分组变量进行比较分析,方便观察不同类别间的差异。
    • 小提琴图能够显示数据的离散程度,通过观察图形的宽度可以了解数据的散布情况。
  • 定义: 在箱线图基础上添加了核密度估计,有助于显示数据分布。

  • hue: 支持分组显示。

  • split: 分割不同类别的小提琴图。

  • 其他常用参数:

  • inner: 指定内部显示的内容(如 box, quartile)。

示例代码:

fig, ax = plt.subplots(figsize=(12, 6))
# split = True 默认是False  当使用hue的时候会生效, 会在一个violin中切开 一半显示一个类别
sns.violinplot(data=tips, x='day', y='total_bill', hue='sex', split=True)
plt.title('Violinplot of Total Bill by Day and Sex')
plt.show()

3. 多变量数据

绘制多变量数据没有固定的套路,可以使用颜色、大小和形状来区分数据:

  1. 通过颜色区分: 使用 hue 参数来区分不同类别。
  2. 通过大小区分: 使用 size 参数调整点的大小以表示数量。

4. Seaborn 主题和样式

使用 sns.set_style() 来设置主题风格,Seaborn 中有五种样式:

  1. white: 白色背景无网格。
  2. whitegrid: 白色网格。
  3. dark: 黑色背景无网格。
  4. darkgrid: 黑色网格(默认)。
  5. ticks: 带刻度线的样式。

5. 数据可视化选择

  1. Seaborn 和 Pandas: 适合快速绘制和探索性分析,但不适合精细化调整。
  2. Matplotlib: 更适合需要精细化控制的绘图需求。

6. 其他知识

1. 数据准备和清洗

在绘图之前,确保数据的质量是非常重要的。以下是一些常用的数据准备和清洗步骤:

  • 处理缺失值
import pandas as pd# 读取数据
df = pd.read_csv('data.csv')# 检查缺失值
print(df.isnull().sum())# 删除缺失值
df.dropna(inplace=True)# 或用填充方式处理缺失值
df.fillna(df.mean(), inplace=True)
  • 处理异常值
# 使用 Z-score 方法识别异常值
from scipy import statsdf = df[(np.abs(stats.zscore(df['column_name'])) < 3)]

Z-score(标准分数)是衡量一个数据点与数据集均值的偏离程度的一种统计量。它表示该数据点与均值的距离,以标准差为单位。具体定义如下:

Z = ( X − μ ) / σ Z=(X−μ)/σ Z=(Xμ)/σ

  • Z : Z − s c o r e Z:Z-score ZZscore
  • X :数据点的值 X:数据点的值 X:数据点的值
  • μ :数据集的均值 μ:数据集的均值 μ:数据集的均值
  • σ :数据集的标准差 σ:数据集的标准差 σ:数据集的标准差

解释:

  • 如果 Z-score 为 0,表示数据点等于均值。
  • 如果 Z-score 为正,表示数据点高于均值;如果为负,表示数据点低于均值。
  • 一般情况下,Z-score 大于 3 或小于 -3 的数据点通常被认为是异常值(outliers)。

2. 图形美化

Seaborn 提供了多种美化图形的方式。可以使用调色板和样式参数。

  • 调色板
import seaborn as sns# 设置调色板
sns.set_palette("pastel")  # 可选 "deep", "muted", "bright", "pastel", "dark", "colorblind"
  • 美化图形
sns.scatterplot(x='x_column', y='y_column', data=df)
plt.title('Title', fontsize=16)
plt.xlabel('X Axis Label', fontsize=14)
plt.ylabel('Y Axis Label', fontsize=14)

3. 保存图形

使用 plt.savefig() 可以将绘制的图形保存到文件中。

import matplotlib.pyplot as plt# 绘图
sns.histplot(df['column_name'])
plt.title('Histogram')# 保存图形
plt.savefig('histogram.png', dpi=300, bbox_inches='tight')

4. 调试和错误处理

在使用 Seaborn 时,可能会遇到一些常见的错误。以下是一些解决方案:

  • KeyError: 当尝试使用不存在的列名时,会抛出 KeyError。确保你使用的列名在 DataFrame 中确实存在。
  • ValueError: 如果数据类型不正确(例如,尝试在数值列上使用分类图),可能会抛出 ValueError。检查数据类型并进行转换:
df['column_name'] = df['column_name'].astype(float)
  • AttributeError: 使用不支持的方法或属性时,可能会抛出此错误。确保你在正确的对象上调用方法。

7. 绘制 线性回归模型

seaborn 中,lmplot 是用于绘制线性回归模型的绘图函数。它结合了回归线和散点图,帮助用户直观地分析两个变量之间的关系,并通过回归线展示趋势。以下是 lmplot 的一些常用参数和基本用法:

语法:

seaborn.lmplot(x, y, data, **kwargs)

参数:

  • x: 字符串,指定数据集中作为 x 轴的变量名称。
  • y: 字符串,指定数据集中作为 y 轴的变量名称。
  • data: 数据集(通常是 Pandas 的 DataFrame),指定要绘制的原始数据。
  • hue: (可选)字符串,指定分类变量,用于在不同类别间绘制不同的回归线和散点。
  • col: (可选)字符串,指定列变量,根据该变量将数据分为多个小图。
  • row: (可选)字符串,指定行变量,与 col 类似,但是按行排列。
  • fit_reg: 布尔值,控制是否绘制回归线(默认为 True)。
  • markers: 用于指定散点的标记类型。
  • palette: 调色板,用于控制不同类别的颜色。

示例用法:

  1. 简单线性回归图

    import seaborn as sns
    import matplotlib.pyplot as plt# 加载示例数据集
    tips = sns.load_dataset('tips')# 绘制总账单与小费之间的线性回归图
    sns.lmplot(x="total_bill", y="tip", data=tips)
    plt.show()
    
  2. 使用分类变量的线性回归

    sns.lmplot(x="total_bill", y="tip", hue="smoker", data=tips)
    plt.show()
    

    上面的例子中,hue="smoker" 会基于是否吸烟绘制不同的回归线。

  3. 多图绘制(基于行和列分类)

    sns.lmplot(x="total_bill", y="tip", col="sex", row="smoker", data=tips)
    plt.show()
    

    这样可以根据 sexsmoker 分类,生成多个子图。

http://www.hrbkazy.com/news/16509.html

相关文章:

  • 上海小企业网站建设四川游戏seo整站优化
  • 单纯做网站的公司如何学会推广和营销
  • 怎么用支付宝做发卡网站周口seo推广
  • 经营网站备案网络营销的基本功能
  • 怎么用优盘做网站登录密钥沈阳网站关键字优化
  • 彩票网站是怎么做的产品推广软文范文
  • 收费用的网站怎么做黑帽seo技术
  • 网站建设协议 模板下载什么是关键词排名优化
  • ps怎么做网站一寸的照片青岛网站seo公司
  • 有效果的网站排名厦门关键词优化seo
  • 广州学校网站建设学编程的正规学校
  • 外贸企业网站建设公司价格2023年5月疫情爆发
  • 视频直播系统开发网站建设外贸平台推广
  • 联影uct528中标价惠州企业网站seo
  • 有了网站源码怎么做app大数据营销 全网推广
  • 响水做网站哪家好2023年免费进入b站
  • 怎么用文本做网站北京网络营销推广公司
  • 西城网站制作公司郑州网站seo
  • 怎样做网站标题的图标免费发布推广信息的软件
  • 怎么开网站做站长如何写市场调研报告
  • 网站建设的价值广州优化营商环境条例
  • 高端网站开发的公司国内快速建站
  • 网站域名分几种市场推广计划
  • wordpress统计分析采集站seo课程
  • 单页网站制作工具赣州seo外包
  • 网站开发 环境中国网站排名查询
  • 做网站的经验和体会google官网登录
  • 东营做网站建设的公司软文有哪些发布平台
  • 网站建设经理山东最新消息今天
  • 网站建设方案保障措施广州专做优化的科技公司