美文网首页
获取数据之Yahoo finance

获取数据之Yahoo finance

作者: 番茄酱的汪 | 来源:发表于2023-11-18 11:13 被阅读0次

    简单的用法

    • 导入yfinance模块:import yfinance as yf
    • 创建Ticker对象:msft = yf.Ticker("MSFT")
    • 获取股票的所有信息:msft.info
    • 获取历史市场数据:hist = msft.history(period="1mo")
    • 显示历史数据的元数据:msft.history_metadata
    • 显示股票的操作信息(股息、拆股、资本收益):msft.actions, msft.dividends, msft.splits, msft.capital_gains
    • 显示股票的股份数量:msft.get_shares_full(start="2022-01-01", end=None)
    • 显示财务报表信息:msft.income_stmt, msft.quarterly_income_stmt, msft.balance_sheet, msft.quarterly_balance_sheet, msft.cashflow, msft.quarterly_cashflow
    • 显示股票的持有者信息:msft.major_holders, msft.institutional_holders, msft.mutualfund_holders
    • 显示未来和历史的收益日期:msft.earnings_dates
    • 显示股票的ISIN代码(国际证券识别码):msft.isin
    • 显示期权到期日期:msft.options
    • 显示新闻:msft.news
    • 获取特定到期日期的期权链:opt = msft.option_chain('YYYY-MM-DD')
    • 使用代理服务器下载数据:msft.history(..., proxy="PROXY_SERVER"), msft.get_actions(proxy="PROXY_SERVER"), msft.get_dividends(proxy="PROXY_SERVER"), msft.get_splits(proxy="PROXY_SERVER"), msft.get_capital_gains(proxy="PROXY_SERVER"), msft.get_balance_sheet(proxy="PROXY_SERVER"), msft.get_cashflow(proxy="PROXY_SERVER"), msft.option_chain(..., proxy="PROXY_SERVER")
    • 初始化多个Ticker对象:tickers = yf.Tickers('msft aapl goog')
    • 访问每个Ticker对象的信息:tickers.tickers['MSFT'].info, tickers.tickers['AAPL'].history(period="1mo"), tickers.tickers['GOOG'].actions
    • 将价格历史数据下载到一个表格中:data = yf.download("SPY AAPL", period="1mo")
    • 使用日志记录:yf.enable_debug_mode() 切换到调试模式并自定义格式
    • 使用自定义请求会话(例如缓存API调用或自定义User-agent标头):传递session参数给Ticker构造函数
    • 处理多级列名:使用pandas的to_csv方法保存DataFrame时,正确读取多级列名;将单个或多个Ticker下载到单个DataFrame中,使用单级列名和一个Ticker列
    • 使用yfinance替代pandas_datareader:使用yf.pdr_override()可以使用yfinance替代pandas_datareader中的get_data_yahoo()方法,并确保返回的数据格式与pandas_datareader的一致

    简单的示例

    • 需要设置代理,所以代码是:
    # 设置代理
    proxies = {
        "http": "http://127.0.0.1:7890",
        "https": "http://127.0.0.1:7890",
    }
    
    prices_df = yf.download(list(sp500_list), start=start_date, 
                            end=end_date,proxy = proxies)
    
    • 简单获取苹果公司的股票收盘价数据
    import yfinance as yf
    
    # 创建Ticker对象
    aapl = yf.Ticker("AAPL")
    
    # 获取近5年的历史市场数据
    history = aapl.history(period="5y",proxy = proxies)
    
    # 获取收盘价数据
    close_prices = history['Close']
    
    # 打印收盘价数据
    print(close_prices)
    
    • 结果获取到历史数据包括:
    ['Open', 'High', 'Low', 'Close', 'Volume', 'Dividends', 'Stock Splits']
    

    Open:当日的开盘价,即股票交易开始时的价格。
    High:当日的最高价,即股票在当日交易中达到的最高价格。
    Low:当日的最低价,即股票在当日交易中达到的最低价格。
    Close:当日的收盘价,即股票交易结束时的价格。
    Volume:当日的交易量,即在当日交易中买卖的股票数量。
    Dividends:当日派发的股息金额。股息是公司向股东派发的利润分配。
    Stock Splits:当日的股票拆分比例。股票拆分是指公司将现有的股票拆分成更多股份的行为,以调整股票价格和股本结构

    相关文章

      网友评论

          本文标题:获取数据之Yahoo finance

          本文链接:https://www.haomeiwen.com/subject/hbouwdtx.html