如何用 python 获取实时的股票数据?

这篇具有很好参考价值的文章主要介绍了如何用 python 获取实时的股票数据?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

需要爬取某个股票的实时数据,每隔一分钟爬取一次,并将数据保存在Excel文件中。我们使用Python来完成这项任务。在完成这任务之前,我们需要掌握两个知识点:Web爬取和Excel文件读写。

Web爬取

Web爬取是指从网站上获取特定数据的过程。我们通常使用Python的Requests库来访问网站。网站会以HTML格式返回相应数据,我们需要使用Beautiful Soup库将HTML格式的数据转换为Python对象进行操作。

#Excel文件读写

Python中,我们可以使用OpenPyXL库来读写Excel文件。使用OpenPyXL,我们可以创建、打开、修改、保存Excel文件,读写单元格、行、列、工作表等。使用OpenPyXL之前,我们需要在系统中安装OpenPyXL库。

在这篇文章中,我们将会介绍如何使用Python来获取实时股票数据并将数据存储在Excel文件中。我们将介绍三种案例:使用Sina Finance API、使用TuShare获取股票数据、使用爬虫库Beautiful Soup爬取Yahoo Finance网站数据。

案例一:使用Sina Finance API获取股票数据

Sina Finance是国内较为权威的股票行情数据提供商之一。它提供了全球股票、期货、外汇、基金、债券、指数等交易品种的实时行情数据。它提供API接口以方便用户获取股票数据。
本案例中,我们将使用Sina Finance提供的API接口获取股票数据。首先,我们需要安装sinafinance库:

pip install sinafinance

接着,我们可以使用如下代码来获取股票实时数据并保存到Excel文件中。

from sinafinance import SinaFinance

import openpyxl
from openpyxl.styles import Font, Alignment
from openpyxl.utils import column_index_from_string

def get_stock_data(code, save_file):
    sf = SinaFinance()
    data = sf.get_realtime_quotes([code])[code]

    wb = openpyxl.Workbook()
    ws = wb.active

    # 设置表头
    header = ['股票代码', '名称', '最新价', '涨跌幅', '成交量', '成交额']
    for i in range(len(header)):
        cell = ws.cell(row=1, column=i+1)
        cell.value = header[i]
        cell.font = Font(bold=True)
        cell.alignment = Alignment(horizontal='center')

    # 填充数据
    row_num = 2
    for i in range(len(data)):
        cell = ws.cell(row=row_num+i, column=column_index_from_string('A'))
        cell.value = data[i]['code']

        cell = ws.cell(row=row_num+i, column=column_index_from_string('B'))
        cell.value = data[i]['name']

        cell = ws.cell(row=row_num+i, column=column_index_from_string('C'))
        cell.value = float(data[i]['price'])

        cell = ws.cell(row=row_num+i, column=column_index_from_string('D'))
        cell.value = float(data[i]['change_pct'])

        cell = ws.cell(row=row_num+i, column=column_index_from_string('E'))
        cell.value = float(data[i]['volume']) / 100

        cell = ws.cell(row=row_num+i, column=column_index_from_string('F'))
        cell.value = float(data[i]['turnover']) / 10000

    # 设置列宽
    column_widths = [12, 12, 10, 10, 12, 12]
    for i in range(len(column_widths)):
        ws.column_dimensions[column_index_from_string('A')+i].width = column_widths[i]

    # 保存Excel文件
    wb.save(save_file)

if __name__ == '__main__':
    get_stock_data('sh000001', 'sh000001.xlsx')

我们可以看到,上面的代码实现了获取实时股票数据的功能,并将数据以Excel格式保存。这个例子演示了如何使用Sina Finance API获取股票数据,这是一个比较快捷方便的方法。

案例二:使用TuShare获取股票数据

TuShare是一个开源的金融数据开放接口平台,它能为开发者提供比较丰富的金融数据API和数据下载。我们可以使用TuShare提供的数据接口来获取股票数据。
首先,我们需要安装tushare库:

pip install tushare

接着,我们可以使用如下代码来获取股票实时数据并保存在Excel文件中。

import tushare as ts

import openpyxl
from openpyxl.styles import Font, Alignment
from openpyxl.utils import column_index_from_string

def get_stock_data(code, save_file):
    data = ts.get_realtime_quotes(code)

    wb = openpyxl.Workbook()
    ws = wb.active

    # 设置表头
    header = ['股票代码', '名称', '最新价', '涨跌幅', '成交量', '成交额']
    for i in range(len(header)):
        cell = ws.cell(row=1, column=i+1)
        cell.value = header[i]
        cell.font = Font(bold=True)
        cell.alignment = Alignment(horizontal='center')

    # 填充数据
    row_num = 2
    for i in range(len(data)):
        cell = ws.cell(row=row_num+i, column=column_index_from_string('A'))
        cell.value = data.iloc[i]['code']

        cell = ws.cell(row=row_num+i, column=column_index_from_string('B'))
        cell.value = data.iloc[i]['name']

        cell = ws.cell(row=row_num+i, column=column_index_from_string('C'))
        cell.value = float(data.iloc[i]['price'])

        cell = ws.cell(row=row_num+i, column=column_index_from_string('D'))
        cell.value = float(data.iloc[i]['changepercent'])

        cell = ws.cell(row=row_num+i, column=column_index_from_string('E'))
        cell.value = float(data.iloc[i]['volume']) / 100

        cell = ws.cell(row=row_num+i, column=column_index_from_string('F'))
        cell.value = float(data.iloc[i]['amount']) / 10000

    # 设置列宽
    column_widths = [12, 12, 10, 10, 12, 12]
    for i in range(len(column_widths)):
        ws.column_dimensions[column_index_from_string('A')+i].width = column_widths[i]

    # 保存Excel文件
    wb.save(save_file)

if __name__ == '__main__':
    get_stock_data(['000001'], '000001.xlsx')

我们可以看到,上面的代码实现了获取实时股票数据的功能,并将数据以Excel格式保存。这个例子演示了如何使用TuShare获取股票数据,这也是一个比较方便的方法。

案例三:使用爬虫库Beautiful Soup爬取Yahoo Finance网站数据

除了使用各种API获取股票数据,我们还可以使用爬虫库获取数据。Yahoo Finance是一个提供股票行情数据的网站。我们可以使用Beautiful Soup爬虫库来获取Yahoo Finance上的股票数据。

首先,我们需要安装beautifulsoup4库:

pip install beautifulsoup4
from bs4 import BeautifulSoup
import requests

import openpyxl
from openpyxl.styles import Font, Alignment
from openpyxl.utils import column_index_from_string

def get_stock_data(code, save_file):
    url = 'https://finance.yahoo.com/quote/{}?p={}'.format(code, code)

    req = requests.get(url)
    html = req.text
    soup = BeautifulSoup(html, 'html.parser')

    data = {}
    data['name'] = soup.find('h1', {'class': 'D(ib) Fz(18px)'}).text
    data['price'] = soup.find('span', {'class': 'Trsdu(0.3s) Fw(b) Fz(36px) Mb(-4px) D(ib)'}).text
    data['change_pct'] = soup.find('span', {'class': 'Trsdu(0.3s) Fw(500) Pstart(10px) Fz(24px) C($positiveColor)'}).text

    wb = openpyxl.Workbook()
    ws = wb.active

    # 设置表头
    header = ['名称', '最新价', '涨跌幅']
    for i in range(len(header)):
        cell = ws.cell(row=1, column=i+1)
        cell.value = header[i]
        cell.font = Font(bold=True)
        cell.alignment = Alignment(horizontal='center')

    # 填充数据
    row_num = 2
    cell = ws.cell(row=row_num, column=column_index_from_string('A'))
    cell.value = data['name']

    cell = ws.cell(row=row_num, column=column_index_from_string('B'))
    cell.value = float(data['price'])

    cell = ws.cell(row=row_num, column=column_index_from_string('C'))
    cell.value = float(data['change_pct'].strip('%'))

    # 设置列宽
    column_widths = [20, 10, 10]
    for i in range(len(column_widths)):
        ws.column_dimensions[column_index_from_string('A')+i].width = column_widths[i]

    # 保存Excel文件
    wb.save(save_file)

if __name__ == '__main__':
    get_stock_data('AAPL', 'AAPL.xlsx')

我们可以看到,上面的代码实现了获取实时股票数据的功能,并将数据以Excel格式保存。这个例子演示了如何使用Beautiful Soup库获取股票数据,这也是一个比较灵活的方法。

通过上面几个例子,我们展示了如何使用Python获取实时股票数据,并将数据以Excel格式保存。这是一个比较常见的任务,可以帮助我们进行股票分析和决策。同时,我们也可以发现,Python尤其是各种数据处理库的应用,可以带给我们极大的便利,提高我们的工作效率。

添闻提供的思路仅供参考。文章来源地址https://www.toymoban.com/news/detail-829230.html

到了这里,关于如何用 python 获取实时的股票数据?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • python爬虫进阶篇:Scrapy中使用Selenium+Firefox浏览器爬取沪深A股股票行情

    上篇记录了Scrapy搭配selenium的使用方法,有了基本的了解后我们可以将这项技术落实到实际需求中。目前很多股票网站的行情信息都是动态数据,我们可以用Scrapy+selenium对股票进行实时采集并持久化,再进行数据分析、邮件通知等操作。 详情请看上篇笔记 items middlewares setti

    2024年02月04日
    浏览(42)
  • 百度松果菁英班——机器学习实践六:股票行情爬取与分析

    飞桨AI Studio星河社区-人工智能学习与实训社区 这篇文章好像有点大,所以上边网页点进去是看不到的,进入环境之后就能看了 定义了一个函数 getHtml(url) ,用于获取指定URL页面的HTML内容。使用 requests.get() 方法发送GET请求,通过fake_useragent生成随机的User-Agent来伪装请求头,避

    2024年04月14日
    浏览(21)
  • 打通选股环节和行情显示链路!股票量化分析工具QTYX-V2.5.1

    目前股票量化分析工具QTYX已经打通了形态驱动选股和数据驱动选股之间的链路。比如双底选股、RPS选股、盘整平台突破选股得到的数据,可以叠加上财务数据、基本面数据、基金持仓数据,然后用条件表达式进行多因子综合排序,从而筛选出优质股票。 如果要更进一步提高

    2024年02月11日
    浏览(27)
  • AI量化炒股是如何获取L2实时行情数据的呢?

    现在先说说证券行情吧。 1。国外的股票行情我就不谈了,这个我不是很了解,今天我来说说国内两大证券交易所,上交所和深交所两大交易所。 上交所的L1和深交所的L1行情,狭义的说就是五档行情,还是比较好获取,渠道很多,但是质量参差不齐。我说说质量稍微好点的,

    2024年01月20日
    浏览(32)
  • Python获取全部股票数据

    目前整个沪深京A股市场总共有5000余支股票,那么我们怎么能获取到这些股票的数据(股价、市值、市盈率、市净率等)呢? 小编常用的有三个网站,分别是东方财富、同花顺、雪球,请自行查阅。 我们以东方财富为例,打开东方财富行情中心,找到全部股票数据后,找到对

    2024年02月15日
    浏览(27)
  • 通过python 获取股票数据的API接口

    用法: ContextInfo.get_bar_timetag (index)。 释义:获取当前K线对应时间的时间戳。 参数:number:K线索引号。 返回:number。 示例: 用法:ContextInfo.get_ sector(sector, realtime)。 释义:获取板块成份股,只支持取指数成份股。

    2024年02月11日
    浏览(28)
  • chatgpt赋能python:Python如何获取股票数据——详细介绍

    Python作为一款专业的编程语言,其应用领域十分广泛,其中之一就是股票数据的获取。本文将详细介绍Python如何获取股票数据的方法,帮助大家快速获取所需的股票信息。 pandas-datareader是一款很受欢迎的Python库,可以用来从多个数据源获取金融数据。使用这个库可以轻松获取

    2024年02月11日
    浏览(37)
  • Python获取股票数据——以沪深300成分股为例

    需求是下载比如从2020-01-01到2022-12-31区间的沪深300成分股每支股票的日K线数据,没错这是个面板数据,原本以为直接通过Python接口可以直接下载到,因为之前找的上证综指啥的用R的pedquant都是直接获取的(看来因为是单支)。 捣鼓了半天,还是我想的简单了…… 试过Akshare、

    2024年03月21日
    浏览(40)
  • python金融数据分析和可视化--03利用Akshare获取股票数据

    AKShare 是基于 Python 的财经数据接口库,目的是实现对股票、期货、期权、基金、外汇、债券、指数、加密货币等金融产品的基本面数据、实时和历史行情数据、衍生数据从数据采集、数据清洗到数据落地的一套工具,主要用于学术研究目的。 AKShare 的特点是获取的是相对权威

    2024年02月05日
    浏览(31)
  • 如何用Python对股票数据进行LSTM神经网络和XGboost机器学习预测分析(附源码和详细步骤),学会的小伙伴们说不定就成为炒股专家一夜暴富了

    最近调研了一下我做的项目受欢迎程度,大数据分析方向竟然排第一,尤其是这两年受疫情影响,大家都非常担心自家公司裁员或倒闭,都想着有没有其他副业搞搞或者炒炒股、投资点理财产品,未雨绸缪,所以不少小伙伴要求我这边分享下关于股票预测分析的技巧。 基于股

    2024年02月02日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包