数据分析都不会,你敢玩基金?Python爬取基金并进行对比!

博客介绍使用Python从新浪财经、东方财富网、同花顺等网站爬取上证50、上证ETF基金等数据,这些网站图表数据通过JSON传递,找到对应API即可抓取。还给出分析上证50的源代码,可显示涨幅折线图并存储数据到EXCEL,还能得到涨幅对比折线图和正相关图。

IHO在新浪财经爬取 上证50在东方财富网爬取 另外两个上证ETF基金编号分别为510100, 510050在同花顺上爬取

这些网站的图表数据都是通过json传递的 所以找到对应的api即可抓取数据

以下是单纯分析上证50的源代码 显示涨幅的折线图以及存储涨幅数据的EXCEL

# -*- coding: utf-8 -*-
"""
Created on Sun Nov 29 21:31:07 2020

@author: asus
"""

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import urllib.request as urllib2
import json
import xlwt

def savedata(name,data):
    #存数据
    xls=xlwt.Workbook()
    sht1=xls.add_sheet(name)
    #添加字段
    sht1.write(0,0,'日期')
    sht1.write(0,1,'涨幅')
    i=0
    for item in data:
        sht1.write(i+1,0,item[0])
        sht1.write(i+1,1,item[1])
        i=i+1
    xls.save('./'+name+'RateData.xls')

#上证50
shangzheng50Url = 'http://push2his.eastmoney.com/api/qt/stock/kline/get?cb=jQuery1124034703156772714716_1606741623783&secid=1.000016&ut=fa5fd1943c7b386f172d6893dbfba10b&fields1=f1%2Cf2%2Cf3%2Cf4%2Cf5&fields2=f51%2Cf52%2Cf53%2Cf54%2Cf55%2Cf56%2Cf57%2Cf58&klt=101&fqt=0&beg=19900101&end=20220101&_=1606741623987'
result = []
 
shangzhengReq=urllib2.Request(shangzheng50Url)
shangzhengRespon=urllib2.urlopen(shangzhengReq)
shangzhengRes = shangzhengRespon.read().decode()
shangzhengRes=shangzhengRes[shangzhengRes.find('klines')+8:len(shangzhengRes)-4]
shangzhengRes_json = json.loads(shangzhengRes)
result2=[]
lastvalue=shangzhengRes_json[0].split(',')[2]
for item in shangzhengRes_json:
    items=item.split(',')
    todayvalue=items[2]
    todayrate=0
    if(float(todayvalue)-float(lastvalue)!=0):
        todayrate=(float(todayvalue)-float(lastvalue))/float(lastvalue)
    lastvalue=todayvalue
    #日期加收盘指数
    result2.append([items[0],todayrate])
savedata('shangzheng50',result2[-101:-1])
result.append(result2[-101:-1])

close_result = []
for instrument in result:
    oneDay_list = []
    for oneDay in instrument:
        oneDay_list.append(float(oneDay[-1]))
    close_result.append(np.array(oneDay_list))
close_result = np.array(close_result)
close_result = close_result.T

df = pd.DataFrame(data=close_result, columns=['shangzheng50'])
df.plot()
plt.show()

运行该程序可以得到下图

 

 

同理将另外三个读取分析一遍就可以得到 涨幅对比折线图 同时换个方法解析的正相关图

如果有帮助到你,能点个赞吗!

PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取

python免费学习资料以及群交流解答点击即可加入

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值