Python可视化在量化交易中的应用(13)_Seaborn直方图

这篇具有很好参考价值的文章主要介绍了Python可视化在量化交易中的应用(13)_Seaborn直方图。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Seaborn中带核密度的直方图的绘制方法

seaborn中绘制直方图使用的是sns.histlot()函数:
sns.histplot(data,x,y,hue,weights,stat=‘count’,bins=‘auto’,binwidth,binrange,discrete,cumulative,common_bins,common_norm,multiple=‘layer’,element=‘bars’,fill,shrink=1,kde,kde_kws,line_kws,thresh=0,pthresh,pmax,cbar,cbar_ax,cbar_kws,palette,hue_order,hue_norm,color,log_scale,legend,ax,**kwargs,)

关键常用参数说明:

data:必需的参数,用于指定数据集。可以是一个Pandas的DataFrame、Numpy的数组、Python的列表或其他类似的数据结构。
x, y:可选参数,用于指定数据集中直方图的x轴和y轴数据。通常情况下,只需要指定x轴数据。
hue:可选参数,用于指定分类变量,根据该变量的不同取值,直方图的颜色会有所区分。
stat:可选参数,用于指定直方图的统计量。默认值为"count",表示计算每个箱体中的观测数量;可以设置为其他值,如"probability"、“density"等。
bins:可选参数,用于指定直方图的箱体数量。可以是一个整数,表示箱体的数量;也可以是一个序列,表示每个箱体的边界值。
binwidth:可选参数,用于指定直方图的箱体宽度。可以是一个整数或浮点数,表示箱体的宽度;也可以是一个字符串,表示使用自动计算的宽度。
binrange:可选参数,用于指定直方图的箱体范围。可以是一个元组,表示箱体的最小值和最大值;也可以是一个字符串,表示使用数据集的最小值和最大值。
cumulative:可选参数,用于指定是否绘制累积直方图。默认值为False,表示不绘制累积直方图;可以设置为True,表示绘制累积直方图。
kde:可选参数,用于指定是否绘制核密度估计曲线。默认值为False,表示不绘制核密度估计曲线;可以设置为True,表示绘制核密度估计曲线。
multiple:可选参数,用于指定是否绘制多个直方图。默认值为False,表示只绘制一个直方图;可以设置为True,表示绘制多个直方图。
element:可选参数,用于指定绘图元素的类型。默认值为"bars”,表示绘制柱状图;可以设置为其他值,如"step"、"poly"等。
shrink:可选参数,用于指定直方图的缩放因子。默认值为1,表示不缩放;可以设置为其他值,如0.5、0.8等。
ax:可选参数,用于指定绘图的坐标轴。如果没有指定,则会创建一个新的坐标轴。
**kwargs:用于传递其他绘图参数,例如图像的标题、标签、颜色等。

使用Seaborn绘制直方图的应用案例

股票开盘价、收盘价、最高价、最低价直方图可视化展示
在这个案例中,我们使用sns.histplot()方法绘制直方图,用以展示中国平安在2023年3月开盘价、收盘价、最高价、最低价的统计分布情况。
代码如下:

import numpy as np
import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties
# 设置为默认字体
plt.rcParams['font.family'] = 'SimHei'
# 显示负数
plt.rcParams['axes.unicode_minus'] = False

# 导入数据
df = pd.read_excel("2023年一季度A股日线行情.xlsx")

# 将日期列转化为日期格式
df["trade_date"] = df["trade_date"].astype("str").apply(lambda x:x[:4]+"-"+x[4:6]+"-"+x[6:])
# 将日期列转换为日期类型,并设置为索引列
df['trade_date'] = pd.to_datetime(df['trade_date'])
df.set_index('trade_date', inplace=True)

# 筛选2023年3月的行情数据
start_date = '2023-03-01'
end_date = '2023-03-31'
df = df.loc[start_date:end_date]

# 筛选出股票代码是"000001.SZ"平安的股票
df = df[df['ts_code'] == '000001.SZ']

# 绘制开盘价、收盘价、最高价、最低价的分价直方图
# 设置各个子图的标题
titles = ['开盘价', '收盘价', '最高价', '最低价']
# 设置各个子图的数据集
datas = ['open','close','high','low']

# 创建一个2x2的子图布局
fig, ax = plt.subplots(2, 2, figsize=(10, 10))
# 依次创建各个子图
for i in range(4):
    sns.histplot(data=df, x=datas[i], kde=True, label = titles[i], ax=ax[i//2, i%2])
    ax[i//2][i%2].set_title(titles[i])
    ax[i//2][i%2].set_xlabel("Price")
    ax[i//2][i%2].set_ylabel("Frequency")
# 调整子图之间的间距
plt.tight_layout()
# 显示图片
plt.show()

代码最终运行效果如下图所示:
Python可视化在量化交易中的应用(13)_Seaborn直方图,Python量化交易可视化,python,开发语言文章来源地址https://www.toymoban.com/news/detail-659736.html

到了这里,关于Python可视化在量化交易中的应用(13)_Seaborn直方图的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据分享|基于Python、Hadoop零售交易数据的Spark数据处理与Echarts可视化分析

    案例数据集是在线零售业务的交易数据,采用Python为编程语言,采用Hadoop存储数据,采用Spark对数据进行处理分析,并使用Echarts做数据可视化。由于案例公司商业模式类似新零售,或者说有向此方向发展利好的趋势,所以本次基于利于公司经营与发展的方向进行数据分析。

    2024年02月11日
    浏览(33)
  • 使用JSON进行数据可视化:在报表和图形展示中的应用

    使用JSON进行数据可视化是一种常见的做法,特别是在数据驱动的网站和应用中。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它易于阅读和写入,同时也易于机器解析和生成。以下是如何在报表和图形展示中使用JSON的一些方法: 报表 : 数据准备 : 首先,你需要

    2024年02月03日
    浏览(41)
  • 数字孪生3D可视化技术在数字化水利行业中的应用

    城市供水数字孪生系统是一种基于web3d开发和数字孪生技术构建的智能运维系统,它可以将实际设备与虚拟模型相结合,实现对城市供水系统的实时监测、预测和优化。 智慧供水系统是智慧水务建设的新目标与新高度,能够实现城市内部原水供水以及污水处理中水务流程的可

    2024年02月07日
    浏览(43)
  • Python应用实例(二)数据可视化(一)

    数据可视化指的是通过可视化表示来探索数据。它与数据分析紧密相关,而数据分析指的是使用代码来探索数据集的规律和关联。数据集可以是用一行代码就能表示的小型数字列表,也可以是数千兆字节的数据。 漂亮地呈现数据并非仅仅关乎漂亮的图片。通过以引人注目的简

    2024年02月16日
    浏览(30)
  • Python应用实例(二)数据可视化(四)

    从网上下载数据,并对其进行可视化。网上的数据多得令人难以置信,大多未经仔细检查。如果能够对这些数据进行分析,就能发现别人没有发现的规律和关联。 访问并可视化的数据以两种常见格式存储:CSV和JSON。我们将使用Python模块csv来处理以CSV格式存储的天气数据,找

    2024年02月16日
    浏览(25)
  • Python应用实例(二)数据可视化(二)

    使用Python来生成随机漫步数据,再使用Matplotlib以引人瞩目的方式将这些数据呈现出来。随机漫步是这样行走得到的路径:每次行走都是完全随机的、没有明确的方向,结果是由一系列随机决策决定的。你可以将随机漫步看作蚂蚁在晕头转向的情况下,每次都沿随机的方向前行

    2024年02月17日
    浏览(31)
  • Python应用实例(二)数据可视化(三)

    本节将使用Python包Plotly来生成交互式图表。需要创建在浏览器中显示的图表时,Plotly很有用,因为它生成的图表将自动缩放以适合观看者的屏幕。Plotly生成的图表还是交互式的:用户将鼠标指向特定元素时,将突出显示有关该元素的信息。 在这个项目中,我们将对掷骰子的结

    2024年02月16日
    浏览(29)
  • Python应用实例(二)数据可视化(五)

    下载一个数据集,其中记录了一个月内全球发生的所有地震,再制作一幅散点图来展示这些地震的位置和震级。这些数据是以JSON格式存储的,因此要使用模块json来处理。Plotly提供了根据位置数据绘制地图的工具,适合初学者使用。你将使用它来进行可视化并指出全球的地震

    2024年02月16日
    浏览(24)
  • 利用Python进行数据可视化Plotly与Dash的应用【第157篇—数据可视化】

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 数据可视化是数据分析中至关重要的一环,它能够帮助我们更直观地理解数据并发现隐藏的模式和趋势。在Python中,有许多强大的工具可以用

    2024年04月14日
    浏览(47)
  • [python] 基于Gradio可视化部署机器学习应用

    Gradio是一个开源的Python库,用于构建机器学习和数据科学演示应用。有了Gradio,你可以围绕你的机器学习模型或数据科学工作流程快速创建一个简单漂亮的用户界面。Gradio适用于以下情况: 为客户/合作者/用户/学生演示你的机器学习模型。 通过自动共享链接快速部署你的模

    2023年04月09日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包