返回顶部
首页 > 资讯 > 后端开发 > Python >python怎么挖掘蛋卷基金投资组合数据分析
  • 939
分享到

python怎么挖掘蛋卷基金投资组合数据分析

2023-06-30 15:06:33 939人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍“python怎么挖掘蛋卷基金投资组合数据分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么挖掘蛋卷基金投资组合数据分析”文章能帮助大家解决问题。一、网页分析1、打开

这篇文章主要介绍“python怎么挖掘蛋卷基金投资组合数据分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python怎么挖掘蛋卷基金投资组合数据分析”文章能帮助大家解决问题。

一、网页分析

1、打开网页

我们随意打开一个蛋卷基金上投资组合的网页,例如:

python怎么挖掘蛋卷基金投资组合数据分析

这里以Microsoft Edge浏览器为例 。

2、查看JSON

选择“XHR”,发现有一个以基金编号命名的文件,单击它,查看请求标头。

点击下载查看详图

GET /djapi/plan/CSI1033 Http/1.1Host: danjuanapp.comConnection: keep-alivesec-ch-ua: " Not A;Brand";v="99", "Chromium";v="90", "Microsoft Edge";v="90"Accept: application/json, text/plain, */*sec-ch-ua-mobile: ?0User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWEBKit/537.36 (Khtml, like Gecko) Chrome/90.0.4430.212 Safari/537.36 Edg/90.0.818.62elastic-apm-traceparent: 00-25105e3e8908ba33898b0f6cd57b8a73-c782a0e5122abe33-01Sec-Fetch-Site: same-originSec-Fetch-Mode: corsSec-Fetch-Dest: emptyReferer: https://danjuanapp.com/strategy/CSI1033Accept-Encoding: gzip, deflate, brAccept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6Cookie: device_id=web_Skhu79T_v; acw_tc=2760774a16215745204941604e9286878fd10c566d03eedbbb0eb93c40e0f5; channel=undefined; xq_a_token=ccd9918c5b2c091c2d0dacb2e264963ba5fb7539; Hm_lvt_b53ede02df3afea0608038748f4c9f36=1621307606,1621428116,1621514481,1621574521; Hm_lpvt_b53ede02df3afea0608038748f4c9f36=1621574634; timestamp=1621574634698

发现好像没什么特别的,说不定没有反爬的机制 ,不如试着直接点开这个链接。

点击下载查看详图

原来这里面存的就是基金基本信息的json!
我们观察这个地址:

https://danjuanapp.com/djapi/plan/CSI1033

发现只要更改最后的编号,就可以获得各个基金的基本信息。

二、数据获取

1、观察json的结构

我们观察一下这个json的结构,这里只截取部分片段。

{"data": {"plan_code": "CSI1033","plan_name": "螺丝钉主动优选组合","yield": "65.93","yield_name": "成立以来收益","yield_middle": "48.03","yield_name_middle": "成立以来年化",……"found_date": "2020-02-03","manager_xq_id": "3079173340","manager_name": "银行螺丝钉","manager_profile_photo": "https://danjuan.aiganggu.com/o2020021580801637267.png","invest_time_type": 2,"invest_time_name": "持有3年以上","invest_money_type": 4,"invest_money_name": "积极增值","found_days": 473,"min_buy_amount": "200","plan_derived": {"end_date": "2021-05-20","nav_grtd": "-0.03","nav_grl1w": "2.38",……"unit_nav": "1.6593","yield_history": [{"yield": "-12.02","name": "近3个月"}, {"yield": "7.40","name": "近6个月"}, {"yield": "42.25",……

我们发现,所有数据都存在 “data” 下, “data” 里有基金的基本信息,当日净值存在 “plan_derived” 下的 “unit_nav” 里,那么我们只要按照这个顺序从中获取数据即可。

三、代码实现

1、基本操作

a. 需要使用的模块

用requests获取页面,用json库将json文件转化为字典。

import requestsimport json

b. 随便设置一个请求标头

header={    'User-Agent': 'Mozilla/5.0 (windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.104 Safari/537.36'}

c. 获取页面信息

这里的code为基金的代码,用requests获取页面以后读出具体的文本内容,存到page里。

code='CSI1033'url='https://danjuanapp.com/djapi/plan/'+codepage=requests.get(url,headers=header).text

我们把page输出出来检查一下,发现我们想要的都在里面。

点击下载查看详图

d. 导入json

因为所有数据都在data里,所以我们直接进入data内即可。

items=json.loads(page)items=items.get("data")

e. 从json中获取需要的信息

基金的名字

name=items.get('plan_name')

基金的当日净值以及净值的记录日期
这些数据在“plan_derived”内。

value=items.get('plan_derived').get("unit_nav")date=items.get('plan_derived').get("end_date")

2、写一个可以重复使用的函数

我们以code作为传入的参数,把刚才的内容组合起来。

def getfund(code):    url='https://danjuanapp.com/djapi/plan/'+code    page=requests.get(url,headers=header).text    items=json.loads(page)    items=items.get("data")    value=items.get('plan_derived').get("unit_nav")    date=items.get('plan_derived').get("end_date")    name=items.get('plan_name')    print("基金编号:",code,'\n基金名:',name,"\n日期:",date,"净值:",value)

3、完整代码

#by concyclicsimport requestsimport jsonheader={    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.104 Safari/537.36'}danjuan=['CSI1033','CSI1032','CSI1038','CSI1029','CSI1006','CSI1065']danjuan.sort()#获取当天信息def getfund(code):    url='https://danjuanapp.com/djapi/plan/'+code    page=requests.get(url,headers=header).text    items=json.loads(page)    items=items.get("data")    value=items.get('plan_derived').get("unit_nav")    date=items.get('plan_derived').get("end_date")    name=items.get('plan_name')    print("基金编号:",code,'\n基金名:',name,"\n日期:",date,"净值:",value)if __name__=='__main__':    for code in danjuan:        getfund(code)

python怎么挖掘蛋卷基金投资组合数据分析

关于“python怎么挖掘蛋卷基金投资组合数据分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网Python频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: python怎么挖掘蛋卷基金投资组合数据分析

本文链接: https://lsjlt.com/news/329679.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python挖掘蛋卷基金投资组合数据分析
    目录一、网页分析1、打开网页2、查看json二、数据获取1、观察json的结构三、代码实现1、基本操作2、写一个可以重复使用的函数3、完整代码一、网页分析 1、打开网页 我们随意打开...
    99+
    2024-04-02
  • python怎么挖掘蛋卷基金投资组合数据分析
    这篇文章主要介绍“python怎么挖掘蛋卷基金投资组合数据分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python怎么挖掘蛋卷基金投资组合数据分析”文章能帮助大家解决问题。一、网页分析1、打开...
    99+
    2023-06-30
  • python/pandas数据挖掘(十四)-groupby,聚合,分组级运算
    https://blog.csdn.net/youngbit007/article/details/54288603 groupbyimport pandas as pddf = pd.DataFrame({"key1":list...
    99+
    2016-09-15
    python/pandas数据挖掘(十四)-groupby 聚合,分组级运算
  • Python数据分析之堆叠数组函数怎么使用
    今天小编给大家分享一下Python数据分析之堆叠数组函数怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。numpy 堆...
    99+
    2023-07-05
  • Python数据分析之Pandas Dataframe怎么合并和去重
    这篇文章主要介绍“Python数据分析之Pandas Dataframe怎么合并和去重”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python数据分析之Pandas Dataf...
    99+
    2023-06-30
  • python怎么应用于数据的基础统计分析
    小编给大家分享一下python怎么应用于数据的基础统计分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最初的设计是用于编...
    99+
    2023-06-14
  • 为什么 Python 对象和 Apache 是大数据分析的完美组合?
    Python 是目前最流行的编程语言之一,而 Apache Hadoop 和 Apache Spark 则是大数据处理和分析领域中最流行的开源软件之一。将 Python 和 Apache 软件结合起来,可以形成一种强大的大数据分析工具。本文...
    99+
    2023-07-06
    对象 apache numy
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作