所以它正在发生。最后,我要问我关于 Stackoverflow 的第一个问题。
我正在尝试从 Morningstar ( https://www.morningstar.com/stocks/xnas/tsla/quote.html ) 获取股票的当前价格,我正在为此使用 Beautifulsoup。
在 HTML 代码中有一个唯一的 ID(“message-box-price”)。我想用它来获取价格,但不幸的是我找不到解决方案。如果有人可以帮助我,那就太好了。
我获取该网站的代码是:
import bs4
import requests
res = requests.get('https://www.morningstar.com/stocks/xnas/tsla/quote.html')
res.raise_for_status()
soup = bs4.BeautifulSoup(res.text, 'lxml')
我尝试了许多不同的方法,但我认为这些是最有希望的方法:
1号:
price = soup.find(id='message-box-price')
price2 = price.find_next()
print(price2)
2号:
price = soup.select("#message-box-price")
price2 = price.find_all_next()
print(price2)
3号:
price = soup.find_all(id="message-box-price")
print(price)
此外,我尝试了它的一些变体并使用 .text 来获取例如值。
错误是:
- AttributeError:“NoneType”对象没有属性“find_previous”
- AttributeError:“列表”对象没有属性“文本”
- TypeError:select()得到了一个意外的关键字参数'attrs'
- 或者我只是得到了一个空列表 -> [ ]