【发布时间】:2019-04-23 01:01:39
【问题描述】:
我尝试从二进制信号网站上抓取表格数据。一段时间后数据会更新,我想在数据更新时获取数据。问题是,当我抓取代码时,它返回空值。该表有一个表标签。
我不确定它是否使用 html 以外的其他内容,因为它无需重新加载即可更新。我必须使用浏览器用户代理才能通过安全性。
当我运行它时,它会返回正确的数据,但我注意到信号 id 增加了 1
<table class="ui stripe hover dt-center table" id="isosignal-table" style="width:100%"><thead><tr><th></th><th class="no-sort">Current Price</th><th class="no-sort">Direction</th><th class="no-sort">Asset</th><th class="no-sort">Strike Price</th><th class="no-sort">Expiry Time</th></tr></thead><tbody><tr :class="[ signal.direction.toLowerCase() == 'call' ? 'call' : 'put' ]" :id="'signal-' + signal.id" :key="signal.id" ref="signals" v-for="signal in signals"><td style="display: none;" v-text="signal.id"></td><td v-text="signal.current_price"></td><td v-html="showDirection(signal.direction)"></td><td v-text="signal.asset"></td><td v-text="signal.strike_price"></td><td v-text="parseTime(signal.expiry)"></td></tr></tbody></table>
table = soup.table
print(table)
但是当我运行整个代码时,它会返回: [] ['', '', '', '', '', '']
from bs4 import BeautifulSoup
from urllib.request import Request, urlopen
url = "https://signals.investingstockonline.com/free-binary-signal-page"
req = Request(url, headers={'User-Agent': 'Mozilla/5.0'})
page = urlopen(req)
data = page.read()
soup = BeautifulSoup(data, 'html.parser')
table = soup.table
table_rows = table.find_all('tr')
for tr in table_rows:
td = tr.find_all('td')
row = [i.text for i in td]
if len(row) < 1:
pass
print(row)
我以为它会显示整个表格,但它只显示空字符串。可能是什么问题?
【问题讨论】:
标签: html python-3.x web-scraping beautifulsoup urllib