【发布时间】:2019-04-28 07:39:12
【问题描述】:
我需要使用 python 从 betfair 网站获取一些数据 我需要一个链接: https://www.betfair.com/www/sports/exchange/readonly/v1/bymarket?_ak=nzIFcwyWhrlwYMrh¤cyCode=EUR&locale=ru&marketIds=1.158145690&rollupLimit=10&rollupModel=STAKE&types=MARKET_STATE,MARKET_RATES,MARKET_DESCRIPTION,EVENT,RUNNER_DESCRIPTION,RUNNER_STATE,RUNNER_EXCHANGE_PRICES_BEST,RUNNER_METADATA,MARKET_LICENCE
为了解决这个问题,我将打开的页面保存为 xml-document,并成功地用这段代码解析它
from bs4 import BeautifulSoup as bs
filedata = open('bymarket.xml')
cont = bs(filedata, 'lxml')
course = cont.find('venue')
print(course.text)
container = cont.find('runners')
item = container.find_all('runnernode')
for horse in item:
runner = horse.find('runnername').text
odds = horse.find('availabletolay').find('price').text
print(runner, odds)
使用此代码,我可以获得所需的结果。 但是,当我尝试直接从页面获取这些数据时,什么也没有发生 - 没有找到任何物品,我没有找到。 请帮助非专业人士获取我需要的信息
【问题讨论】:
-
available to lay 可以有多个价格值 - 您只想要第一个吗?在您的示例中,Kibaar 为 4.9。您在跑步者节点中有多个跑步者。跑步者只能有 1 个子节点吗?
-
是的。我需要第一个值
标签: xml python-3.x parsing web-scraping