我想从“华尔街日报”的网站上提取“资产回报率”。但是,我的代码不够健壮,无法在不同的条件下工作。我能够使用下面的代码提取代码为代码“SCGM”的数据,但作为<span class="marketDelta deltaType-negative">
的“‘AASIA”失败
from lxml import html
import requests
StockData =['SCGM','AASIA']
page_wsj1 = requests.get('http://quotes.wsj.com/MY/'+StockData[x]+'/financials')
wsj1 = html.fromstring(page_wsj1.content)
wsj_fig = wsj1.xpath('//span[@class="marketDelta noChange"]/text()')
ROA = wsj_fig[25]
对于SCGM来说没有问题,但是对于AASIA,它没有工作,因为span类被更改了。对于SCGM,html标记如下所示。全链路这里
<tr> <td> <span class="data_lbl">Return on Assets</span> <span class="data_data"> <span class="marketDelta noChange">18.26</span> </span> </td> </tr>
对于AASIA,html标记如下所示。全链路这里
<tr> <td> <span class="data_lbl">Return on Assets</span> <span class="data_data"> <span class="marketDelta deltaType-negative">-1.36</span> </span> </td> </tr>
如何有一个同时适用于两种情况的代码,或者直接指向“资产回报率”?
发布于 2016-11-08 13:52:06
//td[normalize-space(span) = "Return on Assets"]/span[@class = "data_data"]/span
https://stackoverflow.com/questions/40488422
复制相似问题