使用Python生成股票K线图

可视化股票数据,这里只做简单的处理,只显示k线图。选取的是海通证券(600837)2020年1月1日之后150个交易日的数据。这里代码不多,没有封装成方法,代码如下。数据是提前获取的,获取方法见:使用Python获取股票数据 。

import mpl_finance as mpf
from matplotlib import pyplot as plt
import numpy as np
import pandas as pd


fig = plt.figure(figsize=(12,8))
ax = fig.add_subplot(111)
# 加载数据
df_ma = pd.DataFrame()
original_data = pd.read_csv(r'C:\Users\飘逸\Desktop\600837.csv')
print(original_data)
# 设置显示的交易日数
days = 150
# 生成开盘价、收盘价、最高价、最低价
opens = original_data['Open'][0:days]
closes = original_data['Close'][0:days]
highs = original_data['High'][0:days]
lows = original_data['Low'][0:days]
# 生成时间序列
data_index = original_data['Date'][0:days]
# 使用zip()生成数据列表
ohlc = list(zip(np.arange(0,len(opens)), opens, closes, highs, lows))
# 绘制k线图
mpf.candlestick2_ochl(ax, opens, closes, highs, lows, width=0.6, colorup='r', colordown='g')
# 设置x轴的范围
ax.set_xlim(0,days)
# x轴刻度设置
ax.set_xticks(np.arange(0,days,20))
# 标签设置为日期
ax.set_xticklabels([data_index[index] for index in ax.get_xticks()])
# 设置轴标签
ax.set_xlabel('Date', fontsize = 15)
ax.set_ylabel('Price', fontsize = 15)
ax.set_title('600837')
plt.show()

 

显示如下。

 

  • 8
    点赞
  • 96
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python 中,可以使用第三方库 `mplfinance` 绘制 K 线图。`mplfinance` 是一个基于 matplotlib 的库,提供了简单易用的 API 来绘制股票交易数据的图表,包括 K 线图、成交量图等。 以下是一个绘制 K 线图的示例代码,假设您已经安装了 `mplfinance` 库: ```python import pandas as pd import mplfinance as mpf # 读取股票交易数据 data = pd.read_csv('your_data.csv', index_col=0, parse_dates=True) # 绘制 K 线图 mpf.plot(data, type='candle', volume=True, mav=(5, 10, 20), show_nontrading=True) ``` 这段代码将从 CSV 文件中读取股票交易数据,并绘制 K 线图。其中 `type='candle'` 表示绘制 K 线图,`volume=True` 表示绘制成交量图,`mav=(5, 10, 20)` 表示计算并绘制 5 日、10 日和 20 日的移动平均线,`show_nontrading=True` 表示显示非交易日的数据。 如果您的数据不是 CSV 格式,可以使用 `pandas` 库将数据转换成 `DataFrame` 对象。例如,假设您的数据是一个 Python 列表,包含了每天的开盘价、最高价、最低价和收盘价,可以使用以下代码将数据转换为 `DataFrame` 对象,并绘制 K 线图: ```python import pandas as pd import mplfinance as mpf # 假设数据是一个列表,包含了每天的开盘价、最高价、最低价和收盘价 data = [ [100, 120, 90, 110], # 第一天的数据 [110, 130, 100, 120], # 第二天的数据 [120, 140, 110, 130], # 第三天的数据 # ... ] # 将数据转换为 DataFrame 对象 columns = ['Open', 'High', 'Low', 'Close'] index = pd.date_range(start='20210101', periods=len(data), freq='D') df = pd.DataFrame(data, index=index, columns=columns) # 绘制 K 线图 mpf.plot(df, type='candle', volume=True, mav=(5, 10, 20), show_nontrading=True) ``` 这段代码将把列表数据转换为 `DataFrame` 对象,然后绘制 K 线图。请注意,这里使用了 `pd.date_range()` 函数生成了一个日期索引,以便将数据按日期排序。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值