Selenium&PhantomJS 完成爬取网络代理
Selenium模块是一套完整的Web应用程序测试系统,它包含了测试的录制(SeleniumIDE)、编写及运行(Selenium Remote Control)和测试的并行处理(Selenimu Grid);
那么我们在编写网络爬虫时主要用来了Selenium 的Webdriver 模块 ;
在以上的列表中android 和blackberry 是移动端的浏览器,可以先去掉,common support 也可以先去掉,剩下的除去Phantomjs 则都是常见的浏览器,PhantomJS 是一个基于WebKit 的服务端的JS API,它全面支持web 而不需要浏览器支持,其快速、原生支持各种web 标准;没有界面,则意味着开销小,同时速度也快,那么我们在爬取JS才能返回数据的网站时,没有比selenium和phantomjs 更适合的组合 了;
下载PhantomJS :http://phantomjs.org/
我使用的是windows 环境,那么下载完压缩包后,直接解压,将PhantomJS.exe 放到python 的目录中就可以 了
交互式的小例子我就写了,直接上一个实例代码,也可以将实例中的解析网页源码部分在交互式环境中敲一遍,体验一下;
#!/usr/bin/env python
#coding:utf-8
"""用selenium&PhantomJS 完成的网络爬虫,最适合使用的情形是爬取有JS的网站,但是用来爬取其他网站同样给力""" from selenium import webdriver
from myLog import MyLog as mylog
import sys
reload(sys)
sys.setdefaultencoding('utf-8') class Item(object): #用于存储代理的属性
ip = None
port = None
anonymouns = None
type = None
support = None
local = None
speed = None class GetProxy(object): def __init__(self):
self.starturl = "http://www.kuaidaili.com/free/inha/" #目标网址
self.log = mylog() #二次封装的日志模块
self.urls = self.getUrls()
self.proxyList = self.getProxyList(self.urls)
self.fileName = 'proxy.txt'
self.saveFile(self.fileName,self.proxyList) def getUrls(self): ##生成目标页面代理的网页页面URL
urls = []
for i in xrange(1,3):
url = self.starturl + str(i)
urls.append(url)
self.log.info('get URL %s to urls' %url)
return urls def getProxyList(self,urls): ##分析网页源代码
browser = webdriver.PhantomJS() ## 使用selenium&PhantomJS
proxyList = []
for url in urls:
browser.get(url) #打开网页
browser.implicitly_wait(5) #智能等待加载JS模块
elements = browser.find_elements_by_xpath('//tbody/tr') #使用xpath来解析网页源码
for element in elements:
item = Item()
item.ip = element.find_element_by_xpath('./td[1]').text
item.port = element.find_element_by_xpath('./td[2]').text
item.anonymouns = element.find_element_by_xpath('./td[3]').text
item.type = element.find_element_by_xpath('./td[4]').text
item.support = element.find_element_by_xpath('./td[5]').text
item.local = element.find_element_by_xpath('./td[6]').text
item.speed = element.find_element_by_xpath('./td[7]').text
proxyList.append(item)
self.log.info('add proxy %s: %s to list'%(item.ip,item.port))
browser.quit() #浏览器的退出
return proxyList def saveFile(self,fileName,proxyList): #生成文件
self.log.info('add all proxy to %s'%self.fileName)
with open(fileName,'w') as fp:
for item in proxyList:
# print item.ip
fp.write(item.ip+'\t')
fp.write(item.port + '\t')
fp.write(item.anonymouns + '\t')
fp.write(item.type + '\t')
fp.write(item.support + '\t')
fp.write(item.local + '\t')
fp.write(item.speed + '\n')
self.log.info('write %s:%s to file successfuly......'%(item.ip,item.port)) if __name__ == "__main__":
USE = GetProxy()
由于这几次在使用自己二次封装的myLog模块并未加注释,此次补上,将内置logging模块再次封装,增加了获取用户名,多路径日志输出;
#!/usr/bin/env python
#coding:utf-8
#date 2017_11_30
#author chenjisheng import logging
import getpass class MyLog(object):
'''此类用来封装已有logging类,方便自己使用''' def __init__(self):
self.user = getpass.getuser() #获取使用的用户
self.logger = logging.getLogger(self.user) #初始化一个logger 对象
self.logger.setLevel(logging.DEBUG) #设置logger 的日志级别
self.logfile = "progress_log.log" #设置日志保存的文件
self.formates = logging.Formatter(
"[%(asctime)s] - USERNAME:[%(name)s] - [%(levelname)s] - %(message)s"
) #设置日志的格式
self.Hand = logging.FileHandler(self.logfile) #设置日志的输出为文件
self.Hand.setFormatter(self.formates) #使用日志的格式
self.Hand.setLevel(logging.ERROR) #设置输出为文件的日志级别 self.HandStream = logging.StreamHandler() #设置日志的输出格式为console
self.HandStream.setFormatter(self.formates) #使用日志的格式
self.HandStream.setLevel(logging.DEBUG) #设置输出为窗口的日志级别 self.logger.addHandler(self.HandStream) #增加日志的输出对象给logger(负责发送消息)
self.logger.addHandler(self.Hand) #增加日志的输出对象给logger def debug(self,messages):
self.logger.debug(messages) def info(self,messages):
self.logger.info(messages) def warning(self,messages):
self.logger.warning(messages) def error(self,messages):
self.logger.error(messages) def critical(self,messages):
self.logger.critical(messages) if __name__ == "__main__":
mylog = MyLog()
mylog.debug("I'm debug")
mylog.info("I'm info")
mylog.warning("I'm warning")
mylog.error("I'm error ")
mylog.critical("I'm critical")
代码学习都是在不断练习中成长,下一篇将上传一个简易的爬虫架构。
Selenium&PhantomJS 完成爬取网络代理的更多相关文章
- selenium+phantomjs+pyquery 爬取淘宝商品信息
from selenium import webdriver from selenium.common.exceptions import TimeoutException from selenium ...
- 使用Python爬虫爬取网络美女图片
代码地址如下:http://www.demodashi.com/demo/13500.html 准备工作 安装python3.6 略 安装requests库(用于请求静态页面) pip install ...
- 数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置
数据抓取的艺术(一):Selenium+Phantomjs数据抓取环境配置 2013-05-15 15:08:14 分类: Python/Ruby 数据抓取是一门艺术,和其他软件不同,世界上 ...
- 一起学爬虫——使用selenium和pyquery爬取京东商品列表
layout: article title: 一起学爬虫--使用selenium和pyquery爬取京东商品列表 mathjax: true --- 今天一起学起使用selenium和pyquery爬 ...
- 极简代理IP爬取代码——Python爬取免费代理IP
这两日又捡起了许久不碰的爬虫知识,原因是亲友在朋友圈拉人投票,点进去一看发现不用登陆或注册,觉得并不复杂,就一时技痒搞一搞,看看自己的知识都忘到啥样了. 分析一看,其实就是个post请求,需要的信息都 ...
- 爬虫(四)Selenium + Headless Chrome爬取Bing图片搜索结果
Bing图片搜索结果是动态加载的,如果我们直接用requests去访问页面爬取数据,那我们只能拿到很少的图片.所以我们使用Selenium + Headless Chrome来爬取搜索结果.在开始前, ...
- 爬虫-----selenium模块自动爬取网页资源
selenium介绍与使用 1 selenium介绍 什么是selenium?selenium是Python的一个第三方库,对外提供的接口可以操作浏览器,然后让浏览器完成自动化的操作. sel ...
- 利用selenium和ffmpeg爬取m3u8 ts视频《进击的巨人》
需求 想看下动漫<进击的巨人>,发现到处被和谐,找不到资源,但是在一个视频网站找到了在线播放,https://www.55cc.cc/dongman/17890/player-2-1.ht ...
- python从爬虫基础到爬取网络小说实例
一.爬虫基础 1.1 requests类 1.1.1 request的7个方法 requests.request() 实例化一个对象,拥有以下方法 requests.get(url, *args) r ...
随机推荐
- Log4j未平,Logback 又起!再爆漏洞?
前段时间 Log4j接连爆漏洞的事儿相比把大家都折腾的不轻,很多开发都被连夜叫起来修复漏洞.这几天终于平复一些了. 可是,昨晚,忽然看到技术群和朋友圈,有人开始聊Logback 又爆漏洞了. 这是什么 ...
- springboot目录结构、重要配置文件、重要注解的详解
前面2篇博客已经带着大家搭建了springboot项目,并编写了持久化接口部署到tomcat下访问.这里我们一起补充下springboot的基本信息 一.springboot简单介绍 springbo ...
- 网络编程之新函数inet_pton和inet_ntop
1.头文件 1 #include <arpe/inet.h> 2.inet_pton 函数 A.原型 1 int inet_pton(int family, const char *str ...
- cmake之引入外部项目(引用其他项目)、FetchContent管理子模块(fetchcontent用法)
本文CMAKE版本为3.18 演示环境: Windows+CMake+VS2017 源码下载说明 演示代码是后来传上去的,而且做了些修改,将spdlog_demo由exe改为了lib,但是,spdlo ...
- How many integers can you find(hdu1796)
How many integers can you find Time Limit: 12000/5000 MS (Java/Others) Memory Limit: 65536/32768 ...
- POJ 3278:The merchant(LCA&DP)
The merchant Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 6864 Accepted: 2375 Desc ...
- Robust Pre-Training by Adversarial Contrastive Learning
目录 概 主要内容 代码 Jiang Z., Chen T., Chen T. & Wang Z. Robust Pre-Training by Adversarial Contrastive ...
- Intriguing Properties of Contrastive Losses
目录 概 主要内容 广义对比损失 不同的先验 不同的权重比 Feature Suppression DigitOnImageNet dataset RandBit dataset 代码 [Chen T ...
- docker——nginx运行起不来或者说起来了又挂了
记得刚开始玩docker的时候,想着docker上运行一个nginx代理,于是写了个Dockerfile: FROM nginx:latest WORKDIR . COPY demo.conf /et ...
- JEP解读与尝鲜系列4 - Java 16 中对于 Project Valhalla 的铺垫
这是 JEP 解读与尝鲜系列的第 4 篇,之前的文章如下: JEP解读与尝鲜系列 1 - Java Valhalla与Java Inline class JEP解读与尝鲜系列 2 - JEP 142 ...