用Python爬取yahoo finance上的股票数据并进行可视化

本文介绍了如何使用Python库yfinance获取并可视化黄金、纳斯达克指数、标普500指数等股票的历史价格数据,包括历年和最近一周的数据。读者可以通过修改`symbols`列表自定义股票代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import yfinance as yf
import matplotlib.pyplot as plt
from datetime import timedelta

# 定义要获取数据的股票代码
symbols = ['GC=F', 'BTC-USD', '^IXIC', '^GSPC']  # 黄金、纳斯达克指数、标普500指数

# 获取每只股票的最早时间和最新数据的日期
start_dates = []
end_dates = []

for symbol in symbols:
    ticker = yf.Ticker(symbol)
    history = ticker.history(period='max')
    start_dates.append(history.index[0])
    end_dates.append(history.index[-1])

# 设置start和end为每只股票的最早时间和最新数据的日期
start = max(start_dates).strftime('%Y-%m-%d')
end = min(end_dates).strftime('%Y-%m-%d')

# 获取数据
data = yf.download(symbols, start=start, end=end)['Close']

# 绘制可视化图表
data.plot(subplots=True, figsize=(10, 8))
plt.legend(loc='best')
plt.show()

end = min(end_dates).strftime('%Y-%m-%d')
start = (min(end_dates) - timedelta(days=7)).strftime('%Y-%m-%d')

# 获取数据
data = yf.download(symbols, start=start, end=end)['Close']

# 绘制可视化图表
data.plot(subplots=True, figsize=(10, 8))
plt.legend(loc='best')
plt.show()

请添加图片描述
分别爬取历年数据和最近一周数据,将symbols里的股票更改可以改成自定义的股票。

股票数据爬取可视化是一个非常常见的任务,Python是非常适合这个任务的编程语言。下面是一些常用的Python库和模块,它们可以帮助你完成这个任务: 1. pandas:用于数据处理和分析,可以用来读取和处理股票数据。 2. matplotlib:用于绘制图表和图形,可以用来绘制股票价格和交易量的折线图、柱状图等等。 3. seaborn:基于matplotlib的数据可视化库,可以用来创建更美观的图表。 4. BeautifulSoup:用于解析HTML和XML文档,可以用来爬取股票数据网站的数据。 5. requests:用于HTTP请求,可以用来爬取股票数据网站的数据。 以下是一个简单的股票数据爬取可视化Python程序: ```python import pandas as pd import matplotlib.pyplot as plt import seaborn as sns import requests from bs4 import BeautifulSoup # 爬取股票数据 url = 'https://finance.yahoo.com/quote/GOOG/history?p=GOOG' response = requests.get(url) soup = BeautifulSoup(response.text, 'html.parser') table = soup.find('table', {'data-test': 'historical-prices'}) data = [] for row in table.tbody.find_all('tr'): cols = row.find_all('td') if len(cols) == 7: date = cols[0].text.strip() close = cols[4].text.strip() data.append([date, close]) df = pd.DataFrame(data, columns=['Date', 'Close']) df['Date'] = pd.to_datetime(df['Date']) df['Close'] = df['Close'].astype(float) # 绘制股票价格折线图 sns.set_style('darkgrid') plt.figure(figsize=(12, 6)) plt.plot(df['Date'], df['Close']) plt.title('Google Stock Price') plt.xlabel('Date') plt.ylabel('Close Price') plt.show() ``` 这个程序可以爬取雅虎财经上谷歌公司的股票数据绘制出股票价格的折线图。你可以根据自己的需要修改代码来适应其他股票数据,或者添加其他图表类型和可视化效果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Andrew_Chao

谢谢打赏喵

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值