javascript - node爬取微博
问题描述
刚接触node,想写个爬虫,爬取新浪微博评论,但是发现页面是由JS动态生成的,用http模块爬取不到,然后用phantomjs爬取,(听说会比较慢,运行了近15分钟,这也太慢了,不知是否写错),还是不行,问一下有什么办法能够爬取类似于新浪微博的网页吗?
let page=require('webpage').create();let url='http://weibo.com/1713926427/Etq2WnSiR?filter=hot&root_comment_id=0&type=comment';/*page.settings = { javascriptEnabled: true, loadImages: false, webSecurityEnabled: false, userAgent: ’Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.137 Safari/537.36 LBBROWSER’};*/page.open(url,(status)=>{ console.log('Status:'+status); if(status=='success'){let val = page.evaluate(()=>{ var list_box=document.querySelector('.list_box'); console.log(list_box); return list_box});console.log(val) }else{console.log('failed') } phantom.exit();});
问题解答
回答1:自己写过微博的爬取,有两种思路
仔细看一下应该是有接口去获取相应数据的然后用正则去匹配
微博提供了开发者API接口的,虽然用着比较麻烦
相关文章:
1. docker不显示端口映射呢?2. docker api 开发的端口怎么获取?3. php - 想要远程推送emjio ios端怎么搞 需要怎么配合4. angular.js - node.js中下载的angulae无法引入5. python 多进程 或者 多线程下如何高效的同步数据?6. vim - docker中新的ubuntu12.04镜像,运行vi提示,找不到命名.7. angular.js - Angular 刷新页面问题8. android - 添加multidex后在部分机型上产生anr的问题,该如何解决9. docker-compose 为何找不到配置文件?10. 一个走错路的23岁傻小子的提问
