如何用爬虫抓取股市数据并生成分析报表

2024-05-02 08:38

1. 如何用爬虫抓取股市数据并生成分析报表

我用前嗅的forespider数据采集软件爬过股市信息的,比较简单,分析了一下历史股价,目前数据还不多没做太多分析。过几天再说

如何用爬虫抓取股市数据并生成分析报表

2. 如何用爬虫抓取股市数据并生成分析报表

就是当天这个股票上涨和下跌的比比如说这个股票开盘是10元,开盘他就涨,涨到了10.5元。然后又跌到10.1元,那么现在的强弱应该是5:4=1.25。都是以次类推

3. 如何用python 爬虫抓取金融数据

获取数据是数据分析中必不可少的一部分,而网络爬虫是是获取数据的一个重要渠道之一。鉴于此,我拾起了Python这把利器,开启了网络爬虫之路。
本篇使用的版本为python3.5,意在抓取证券之星上当天所有A股数据。程序主要分为三个部分:网页源码的获取、所需内容的提取、所得结果的整理。
一、网页源码的获取
很多人喜欢用python爬虫的原因之一就是它容易上手。只需以下几行代码既可抓取大部分网页的源码。

import urllib.requesturl='ar.com/stock/ranklist_a_3_1_1.html'  #目标网址headers={"User-Agent":"Mozilla/5.0 (Windows NT 10.0; WOW64)"}  #伪装浏览器请求报头request=urllib.request.Request(url=url,headers=headers)  #请求服务器response=urllib.request.urlopen(request)  #服务器应答content=response.read().decode('gbk')   #以一定的编码方式查看源码print(content)  #打印页面源码 

虽说抓一页的源码容易,不过在一个网站内大量抓取网页源码却经常遭到服务器拦截,顿时感觉世界充满了恶意。于是我开始研习突破反爬虫限制的功法。
1.伪装流浪器报头
很多服务器通过浏览器发给它的报头来确认是否是人类用户,所以我们可以通过模仿浏览器的行为构造请求报头给服务器发送请求。服务器会识别其中的一些参数来识别你是否是人类用户,很多网站都会识别User-Agent这个参数,所以请求头最好带上。有一些警觉性比较高的网站可能还会通过其他参数识别,比如通过Accept-Language来辨别你是否是人类用户,一些有防盗链功能的网站还得带上referer这个参数等等。
2.随机生成UA
证券之星只需带User-Agent这个参数就可以抓取页面信息了,不过连续抓取几页就被服务器阻止了。于是我决定每次抓取数据时模拟不同的浏览器发送请求,而服务器通过User-Agent来识别不同浏览器,所以每次爬取页面可以通过随机生成不同的UA构造报头去请求服务器,
3.减慢爬取速度
虽然模拟了不同浏览器爬取数据,但发现有的时间段可以爬取上百页的数据,有时候却只能爬取十来页,看来服务器还会根据你的访问的频率来识别你是人类用户还是网络爬虫。所以我每抓取一页都让它随机休息几秒,加入此句代码后,每个时间段都能爬取大量股票数据了。
4.使用代理IP
天有不测风云,程序在公司时顺利测试成功,回寝室后发现又只能抓取几页就被服务器阻止了。惊慌失措的我赶紧询问度娘,获知服务器可以识别你的IP,并记录此IP访问的次数,可以使用高匿的代理IP,并在抓取的过程中不断的更换,让服务器无法找出谁是真凶。此功还未修成,欲知后事如何,请听下回分解。
5.其他突破反爬虫限制的方法
很多服务器在接受浏览器请求时会发送一个cookie文件给浏览器,然后通过cookie来跟踪你的访问过程,为了不让服务器识别出你是爬虫,建议最好带上cookie一起去爬取数据;如果遇上要模拟登陆的网站,为了不让自己的账号被拉黑,可以申请大量的账号,然后再爬入,此处涉及模拟登陆、验证码识别等知识,暂时不再深究...总之,对于网站主人来说,有些爬虫确实是令人讨厌的,所以会想出很多方法限制爬虫的进入,所以我们在强行进入之后也得注意些礼仪,别把人家的网站给拖垮了。
二、所需内容的提取
获取网页源码后,我们就可以从中提取我们所需要的数据了。从源码中获取所需信息的方法有很多,使用正则表达式就是比较经典的方法之一。我们先来看所采集网页源码的部分内容。


为了减少干扰,我先用正则表达式从整个页面源码中匹配出以上的主体部分,然后从主体部分中匹配出每只股票的信息。代码如下。
pattern=re.compile('')  body=re.findall(pattern,str(content))  #匹配之间的所有代码pattern=re.compile('>(.*?)和<之间的所有信息
其中compile方法为编译匹配模式,findall方法用此匹配模式去匹配出所需信息,并以列表的方式返回。正则表达式的语法还挺多的,下面我只罗列所用到符号的含义。
语法    说明    
.    匹配任意除换行符“\n”外的字符    
*    匹配前一个字符0次或无限次    
?    匹配前一个字符0次或一次    
\s    空白字符:[\t\r\n\f\v]    
\S    非空白字符:[^\s]    
[...]    字符集,对应的位置可以是字符集中任意字符    
(...)    被括起来的表达式将作为分组,里面一般为我们所需提取的内容    
正则表达式的语法挺多的,也许有大牛只要一句正则表达式就可提取我想提取的内容。在提取股票主体部分代码时发现有人用xpath表达式提取显得更简洁一些,看来页面解析也有很长的一段路要走。
三、所得结果的整理
通过非贪婪模式(.*?)匹配>和<之间的所有数据,会匹配出一些空白字符出来,所以我们采用如下代码把空白字符移除。
stock_last=stock_total[:] #stock_total:匹配出的股票数据for data in stock_total:  #stock_last:整理后的股票数据if data=='':stock_last.remove('')
最后,我们可以打印几列数据看下效果,代码如下
print('代码','\t','简称','   ','\t','最新价','\t','涨跌幅','\t','涨跌额','\t','5分钟涨幅')for i in range(0,len(stock_last),13):        #网页总共有13列数据print(stock_last[i],'\t',stock_last[i+1],' ','\t',stock_last[i+2],'  ','\t',stock_last[i+3],'  ','\t',stock_last[i+4],'  ','\t',stock_last[i+5])

如何用python 爬虫抓取金融数据

4. 如何用爬虫抓取股市数据并生成分析报表

要想自己采也行,我之前采过股市数据。用的是ForeSpider这个软件。这个软件他自身有数据挖掘分析功能,自己就进行聚类分类,统计分析了,采集的结果入库后可以形成分析报表,直接浏览就行了,还是很方便的,你可以去看看。操作也是不难,非计算机专业的人也能使。
希望我的回答对你有帮助。

5. python爬虫获取东方财富股票论坛内容分析,怎样

付费可以帮写

python爬虫获取东方财富股票论坛内容分析,怎样

6. 如何用爬虫抓取股市数据并生成分析报表

数据量太大太大,爬取数据太慢太慢,难!!!!
建数据仓库,将抓取数据放入仓库,再按自己思路做运算,得到各种报表。
靠爬虫,难度太大。

7. 如何用爬虫抓取股市数据并生成分析报表

有的公司公布财务资料时以利润及利润分配表代替损益表,利润及利润分配表就是在损益表的基础上再加上利润分配的内容。通过阅读与分析利润表,股东可以了解公司一定期间内业务经营情况及利润形成的全过程;了解公司利润计划的执行情况;分析收入、成本、费用、税金各项目的构成比例是否合理;了解投资价值和投资回报率;预测公司在未来期间的经营业绩趋势;了解上市公司利润分配情况;分析公司利润分配程序和分配比例的合法性和合理性。

如何用爬虫抓取股市数据并生成分析报表

8. 如何用爬虫抓取股市数据并生成分析报表

没听说过
最新文章
热门文章
推荐阅读