Python获取股票数据并绘制相应K线图,看这个就够了!

5 篇文章 0 订阅
1 篇文章 0 订阅

前言

说明

有人的地方就有江湖,有交易的地方就有金融。
在这里插入图片描述

出于对金融证券的兴趣,作者去年疫情期间开始对金融证券以及数据分析进行学习,去年也已获得证券从业资格证,完整数据分析的内容实现已在两个月前完成。
此篇仅为作者完成的完整数据分析的部分内容(股票数据获取及K线绘制的简化内容)。
在这里插入图片描述

注意

-----------------------------------------------------------------------------------
投资有风险,入市需谨慎
本文不构成任何投资建议!
-----------------------------------------------------------------------------------

数据获取

Tushare获取股票数据

在这里插入图片描述

通过tushare调用token进行获取
直接进入–> tushare

基本调用可查看文章:Tushare调用Token口令对股票数据进行获取

在这里插入图片描述
tushare注册后获得接口令牌即token
在这里插入图片描述

获取医疗器械板块数据(代码部分)

下面开始在python中通过代码获取相关数据。
以医疗器械板块2020年1月1号至2020年3月31号为例

import tushare as ts
import warnings

warnings.simplefilter('ignore')
token = 'XXXXXXXXXXXX'	# 以自己的token为例
pro = ts.pro_api(token)


def get_Plate(stock_code):
    df = pro.ths_daily(ts_code=stock_code, start_date='20200101', end_date='20200331')
    # df = pd.DataFrame(df)
    # 选择时间段2020年初爆发疫情最近3个月

    csv_name = '医疗器械概念_pr.csv'
    df.to_csv(csv_name)

    print("医疗器械概念板块 + ':\n', df)


if __name__ == '__main__':
    get_Plate('885539.TI')  # 医疗器械概念板块

在这里插入图片描述

获取股票数据(代码部分)

在python中进行数据获取(以迈瑞医疗2020年1月1号至2020年3月31号为例)

import tushare as ts
import warnings

warnings.simplefilter('ignore')
token = 'XXXXXXXXXXXX'	# 以自己的token为例
pro = ts.pro_api(token)


def get_Stock(stock_code):
# 获取这类股票的日线
    df = pro.daily(ts_code=stock_code, start_date='20200101', end_date='20200331') 
    # 选择时间段2020年初爆发疫情最近3个月
    stock_name = stock_code[:6]
    df.to_csv(stock_name + '.csv')
    print(stock_name + ':\n', df)


if __name__ == '__main__':
    get_Stock('300760.SZ')  # 迈瑞医疗

获取成功,如下
在这里插入图片描述

数据预处理

变量中文化(代码部分)

import json


def get_Stock(stock_code):
    df = pro.daily(ts_code=stock_code, start_date='20200101', end_date='20200331')
    # 选择时间段2020年初爆发疫情最近3个月
    columns_change = '{"ts_code":"股票代码","trade_date":"交易日期","open":"开盘价","high":"最高价","low":"最低价","close":"收盘价",' \
                     '"pre_close":"昨日收盘价","change":"涨跌额","pct_chg":"涨跌幅","vol":"成交量","amount":"成交额"} '
    columns_changes = json.loads(columns_change)
    df.rename(columns=columns_changes, inplace=True)
    stock_name = stock_code[:6]
    df.to_csv(stock_name + "_pr" + '.csv')
    print(stock_name + "预处理" + ':\n', df)

可得如下
在这里插入图片描述

K线绘制

对于相关金融数据的可视化处理,下面主要通过Python中的可视化工具库来完成,包括Seaborn、Matplotlib等优秀的图像处理库,以及mplfinance这类优秀的金融数据分析工具库等。
(下面以Matplotlib为例~~)

代码部分

import pandas as pd
import numpy as np
from matplotlib import pyplot as plt
from mplfinance.original_flavor import candlestick_ochl
from matplotlib import ticker
import warnings

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
warnings.simplefilter("ignore")


class VisualizingKline:    # 声明:定义一个制作K线的类

    def read_file(self):
        df_stock = pd.read_csv(f'../数据获取/{self}_pr.csv', index_col=[0], dtype={'股票代码': 'str', '交易日期': 'str'})  # 去掉第一列数字列column
        print(df_stock.head(3))     # 打印头三行
        print(df_stock.tail(3))     # 打印尾三行
        df_stock_pr = df_stock.query('交易日期 >= "20200101"').reset_index()
        df_stock_pr = df_stock_pr.sort_values(by='交易日期', ascending=True)  # 创建df_stock_pr接收数据按照日期降序排列的文件
        df_stock_pr['dates'] = np.arange(0, len(df_stock_pr))   # len(df_stock_pr):记录数
        fig, ax = plt.subplots(figsize=(9, 5))
        fig.subplots_adjust(bottom=0.2)
        candlestick_ochl(ax, quotes=df_stock_pr[['dates', '开盘价', '收盘价', '最高价', '最低价', '涨跌额']].values,
                         colorup='r', colordown='g', width=0.65, alpha=0.85)
        dt_tick = df_stock_pr['交易日期'].values

        def fm_d(x):
            if (x < 0) or (x > len(dt_tick)-1):
                return ''
            return dt_tick[int(x)]

        ax.xaxis.set_major_formatter(ticker.FuncFormatter(fm_d))
        # 按一定规则选取并在水平轴上显示时间刻度
        plt.xticks(rotation=15)  # 关于交易日期变量的旋转角度
        ax.set_ylabel('交易价格')
        plt.xlabel('交易日期')
        plt.title(f'{self}的K线图生成如下')
        plt.grid(True)  # 网格效果
        plt.show()

结果展示

得到迈瑞医疗300760的K线图如下
在这里插入图片描述

写在最后

在这里插入图片描述
注:不构成任何投资建议,股市有风险,投资需谨慎!
-----------------------------------------------------------------------------------
未经作者允许,不得转载
-----------------------------------------------------------------------------------

如有帮助,博主想喝杯瑞幸,1毛也是支持,谢谢!
在这里插入图片描述

  • 5
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,以下是一个简单的股票数据分析、绘制K线图、价格走势图、收益率计算的Python代码。 首先,我们需要安装一些必要的库: ```python pip install pandas numpy matplotlib mplfinance ``` 然后,我们需要获取股票数据。这里我们以阿里巴巴(BABA)为例,使用Yahoo Finance API来获取数据: ```python import pandas as pd import numpy as np import yfinance as yf # 获取阿里巴巴(BABA)的股票数据 baba = yf.download('BABA', start='2019-01-01', end='2021-01-01') ``` 接下来,我们可以对数据进行一些基本的处理和分析。例如,我们可以计算每天的涨跌幅和收盘价的移动平值: ```python # 计算每天的涨跌幅 baba['Daily Return'] = baba['Adj Close'].pct_change() # 计算收盘价的5日移动平值和30日移动平值 baba['MA5'] = baba['Adj Close'].rolling(5).mean() baba['MA30'] = baba['Adj Close'].rolling(30).mean() ``` 然后,我们可以使用mplfinance库来绘制K线图和价格走势图: ```python import mplfinance as mpf # 绘制K线图 mpf.plot(baba, type='candle', mav=(5, 30), volume=True) # 绘制价格走势图 mpf.plot(baba['Adj Close'], type='line', mav=(5, 30)) ``` 最后,我们可以计算收益率,并打印出来: ```python # 计算收益率 cumulative_return = (1 + baba['Daily Return']).cumprod() print('Cumulative Return:', cumulative_return[-1]) ``` 完整代码如下: ```python import pandas as pd import numpy as np import yfinance as yf import mplfinance as mpf # 获取阿里巴巴(BABA)的股票数据 baba = yf.download('BABA', start='2019-01-01', end='2021-01-01') # 计算每天的涨跌幅 baba['Daily Return'] = baba['Adj Close'].pct_change() # 计算收盘价的5日移动平值和30日移动平值 baba['MA5'] = baba['Adj Close'].rolling(5).mean() baba['MA30'] = baba['Adj Close'].rolling(30).mean() # 绘制K线图 mpf.plot(baba, type='candle', mav=(5, 30), volume=True) # 绘制价格走势图 mpf.plot(baba['Adj Close'], type='line', mav=(5, 30)) # 计算收益率 cumulative_return = (1 + baba['Daily Return']).cumprod() print('Cumulative Return:', cumulative_return[-1]) ``` 这个代码可以直接运行,会输出阿里巴巴股票K线图、价格走势图和累计收益率。当然,你也可以将代码中的阿里巴巴股票替换成其他股票,进行相应数据分析和绘图。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值