webdriver.PhantomJS 有个疑问求玩蛇高手

2016-08-03 16:58:37 +08:00
 JianBingXia

最近想获取一个 js 生成的网页 拿百度举个例子 搜刘德华的图片

http://image.baidu.com/search/index?tn=baiduimage&ps=1&ct=201326592&lm=-1&cl=2&nc=1&ie=utf-8&word=%E5%88%98%E5%BE%B7%E5%8D%8E#z=0&pn=&ic=0&st=-1&face=0&s=0&lm=-1

这是一个 js 生成的网页

如果我用

driver = webdriver.PhantomJS()

driver.get(url)

driver.page_source

获取到的还是 js 之前的 html,请问我该如何获取之后生成的整页 html 呢?

谢谢

ps.使用driver.find_elements_by_xpath('//a[@name="pn0"]/img')和get_attribute("src") 是可以获取到内容的,如果我想获取整个img的html标签应该怎么取呢?

2613 次点击
所在节点    Python
1 条回复
Magic347
2016-08-03 18:34:39 +08:00
页面应该是有 1 个 ajax 请求的:
http://image.baidu.com/search/avatarjson?tn=resultjsonavatarnew&ie=utf-8&word=%E5%88%98%E5%BE%B7%E5%8D%8E&cg=star&pn=60&rn=30&itg=0&z=0&fr=&lm=-1&ic=0&s=0&st=-1&gsm=d0000003c

word 参数作为输入关键词,注意 urlencode 一下
pn 参数来控制页长偏移量

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/296881

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX