python实现ip代理池功能示例


Posted in Python onJuly 05, 2019

本文实例讲述了python实现ip代理池功能。分享给大家供大家参考,具体如下:

爬取的代理源为西刺代理。

  • 用xpath解析页面
  • 用telnet来验证ip是否可用
  • 把有效的ip写入到本地txt中。当然也可以写入到redis、mongodb中,也可以设置检测程序当代理池中的ip数不够(如:小于20个)时,启动该脚本来重新获取ip,本脚本的代码也要做相应的改变。
# !/usr/bin/env python
# -*- coding: utf-8 -*-
# @Version   : 1.0
# @Time     : 2018/10/23 上午10:40
# @Author    : Yeoman
# @Description :
import urllib.request
import lxml.etree
import telnetlib
import os
headers = {
  'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.67 Safari/537.36'
}
def get_proxy(page_num):
  # 获取页面
  req = urllib.request.Request('http://www.xicidaili.com/nn/{}'.format(page_num), headers=headers) # 构造request请求
  response = urllib.request.urlopen(req) # 发送请求
  html = response.read()
  html = html.decode('utf-8')
  # print(html)
  # 解析页面
  proxy_list = []
  selector = lxml.etree.HTML(html)
  rows = selector.xpath('//*[@id="ip_list"]//tr')
  rows_total = len(rows)
  row_xpath_head = '//*[@id="ip_list"]//tr['
  row_ip_xpath_tail = ']/td[2]/text()'
  row_port_xpath_tail = ']/td[3]/text()'
  for i in range(1, rows_total):
    ip_xpath = row_xpath_head + str(i+1) + row_ip_xpath_tail
    port_xpath = row_xpath_head + str(i+1) + row_port_xpath_tail
    ip = selector.xpath(ip_xpath)[0]
    port = selector.xpath(port_xpath)[0]
    ip_port = ip + ':' + port
    proxy_list.append(ip_port)
  return proxy_list
# 检测代理ip是否可用
def test_proxy_ip_port(proxy_ip_port):
  print('当前代理ip:{}'.format(proxy_ip_port))
  ip_port = proxy_ip_port.split(':')
  ip = ip_port[0]
  port = ip_port[1]
  # 用telnet来验证ip是否可用
  try:
    telnetlib.Telnet(ip, port, timeout=10)
  except:
    return False
  else:
    return True
# 把有效的ip写入本地
def write_ip(proxy_ip):
  with open('./ip.txt', 'a') as f:
    f.write(proxy_ip + '\n')
# 删除文件
def del_file():
  file_path = './ip.txt'
  if os.path.exists(file_path):
    os.remove(file_path)
def run():
  del_file()
  proxy_ip_port_list = []
  for i in range(1, 6): # 前5页
    proxy_ip_port_list += get_proxy(i)
  for i in range(100): # 一页有100条
    proxy_ip_port = proxy_ip_port_list[i]
    is_valid = test_proxy_ip_port(proxy_ip_port)
    print(is_valid)
    if is_valid:
      # 写入ip到本地
      write_ip(proxy_ip_port)
if __name__ == '__main__':
  run()

更多关于Python相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python正则表达式用法总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python BeautifulSoup中文乱码问题的2种解决方法
Apr 22 Python
Python计算回文数的方法
Mar 11 Python
Python numpy实现数组合并实例(vstack,hstack)
Jan 09 Python
Python cookbook(数据结构与算法)将序列分解为单独变量的方法
Feb 13 Python
python使用筛选法计算小于给定数字的所有素数
Mar 19 Python
快速解决pandas.read_csv()乱码的问题
Jun 15 Python
解决安装pycharm后不能执行python脚本的问题
Jan 19 Python
详解python selenium 爬取网易云音乐歌单名
Mar 28 Python
树莓派+摄像头实现对移动物体的检测
Jun 22 Python
Python的numpy库下的几个小函数的用法(小结)
Jul 12 Python
python GUI库图形界面开发之PyQt5菜单栏控件QMenuBar的详细使用方法与实例
Feb 28 Python
pycharm 2018 激活码及破解补丁激活方式
Sep 21 Python
解决yum对python依赖版本问题
Jul 05 #Python
python写入文件自动换行问题的方法
Jul 05 #Python
Python Numpy计算各类距离的方法
Jul 05 #Python
ERLANG和PYTHON互通实现过程详解
Jul 05 #Python
python如何读取bin文件并下发串口
Jul 05 #Python
anaconda如何查看并管理python环境
Jul 05 #Python
python笔记之mean()函数实现求取均值的功能代码
Jul 05 #Python
You might like
PHP最常用的2种设计模式工厂模式和单例模式介绍
2012/08/14 PHP
PHP文件上传类实例详解
2016/04/08 PHP
centos+php+coreseek+sphinx+mysql之一coreseek安装篇
2016/10/25 PHP
php中青蛙跳台阶的问题解决方法
2018/10/14 PHP
JS类的封装及实现代码
2009/12/02 Javascript
javascript中使用css需要注意的地方小结
2010/09/01 Javascript
jQuery 无刷新分页实例代码
2013/11/12 Javascript
JavaScript—window对象使用示例
2013/12/09 Javascript
jQuery 取值、赋值的基本方法整理
2014/03/31 Javascript
在Linux上用forever实现Node.js项目自启动
2014/07/09 Javascript
javascript中动态函数用法实例分析
2015/05/14 Javascript
详解Vue使用 vue-cli 搭建项目
2017/04/20 Javascript
详解Vue-axios 设置请求头问题
2018/12/06 Javascript
vue.js实现备忘录demo
2019/06/26 Javascript
js正则表达式简单校验方法
2021/01/03 Javascript
Python中请使用isinstance()判断变量类型
2014/08/25 Python
python处理二进制数据的方法
2015/06/03 Python
在Python的Django框架中获取单个对象数据的简单方法
2015/07/17 Python
Python环境变量设置方法
2016/08/28 Python
Python中格式化format()方法详解
2017/04/01 Python
Python中字典和集合学习小结
2017/07/07 Python
Python列表删除的三种方法代码分享
2017/10/31 Python
python实现指定文件夹下的指定文件移动到指定位置
2018/09/17 Python
详解Python 实现 ZeroMQ 的三种基本工作模式
2020/03/24 Python
HTML5是什么 HTML5是什么意思 HTML5简介
2012/10/26 HTML / CSS
iPhoneX安全区域(Safe Area)底部小黑条在微信小程序和H5的屏幕适配
2020/04/08 HTML / CSS
优秀学生获奖感言
2014/02/15 职场文书
幼儿园教师教育感言
2014/02/28 职场文书
人事专员岗位职责范本
2014/03/04 职场文书
风险评估实施方案
2014/03/09 职场文书
2014年六一儿童节演讲稿
2014/05/23 职场文书
大学生英文求职信范文
2015/03/19 职场文书
房地产置业顾问岗位职责
2015/04/11 职场文书
为自己工作观后感
2015/06/11 职场文书
Java实现学生管理系统(IO版)
2022/02/24 Java/Android
python可视化分析绘制带趋势线的散点图和边缘直方图
2022/06/25 Python