python爬虫学习

什么是网络爬虫?

  • 别名:网页蜘蛛,网络机器人
  • 定义:按照一定规则,自动抓取万维网信息的程序脚本. 在网络上爬行的一只蜘蛛

如何用python3写爬虫?

基础知识

  • urllib
  • 正则表达式
  • python爬虫框架Scrapy

urllib

获取一个网页的源码
    #!/usr/bin/env python3

    import urllib, urllib.request

    response = urllib.request.urlopen("http://www.baidu.com")
    print response.read().decode('uft-8's)
    #!/usr/bin/env python3

    import urllib, urllib.request

    req = urllib.request.Request("http://www.baidu.com")
    response = urllib.request.urlopen(req)
    print response.read().decode('uft-8's)

上面第二种写法保存了中间结果req

urlencode: 字典转换为url格式
>> import urllib.parse
>> data = {}
>> data['word']='John Smith'
>> urllib.parse.urlencode(data)

'word=John+Smith'

deque

导入模块
from collections import deque
  • 初始化

    queue = deque(['John', 'Bush', 'Frank'])
  • 入队列

    queue.append('Ken')
  • 出队列

    queue.popleft()

集合运算

表达式含义
a & ba交b
a | ba并b
a - b在a中,且不在b中
a ^ b不同时在a和b中

字典和集合的 {}

  • 字典:
    • 空字典: dic = {}
  • 集合:
    • 空集合: mySet = set(), 如果用 {}就成字典了

GET与POST

  • GET: 链接中包含了所有的参数,使得传输到信息不是很安全
  • POST: 不会在网址上显示所有的参数, 信息包含在一个data结构里面

Charles

  • 在Mac上学习和分析http可以用Charles.
  • 我们的爬虫需要伪装成浏览器,通过Charles可以查看我们的请求报文
    #!/usr/bin/env python3

    import urllib.request

    url = 'http://www.baidu.com/'
    req = urllib.request.Request(url, headers = {
        'Connection': 'Keep-Alive',
        'Accept': 'text/html, application/xhtml+xml, */*',
        'Accept-Language': 'en-US,en;q=0.8,zh-Hans-CN;q=0.5,zh-Hans;q=0.3',
        'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko'
    })

    urlop = urllib.request.urlopen(req)
通过Charles查看request报文


方法

下载图片

# python3

localSavePath = "/Users/Smith/Picture/"
def downloadPicture(url):
    pattern = r'http://\w+?\.(jpg|png)'
    match = re.search(pattern, url)
    if match:
        filename = localSavePath + match.group()
        urllib.request.urlretrieve(url, filename)

动手实践

下面我从一个起始页面开始爬,只要发现jpg格式的图片就把它保存起来。

  • 发现一个新链接,保存到queue
  • 已经访问过的页面,保存到visited集合中,防止重复访问
#!/usr/bin/env python3

# -*- coding:utf-8 -*-

import urllib.request
import re

from collections import deque

localSavePath = "/Users/Smith/Downloads/Pictures/"

queue = deque()
visited = set()

initialPage = 'http://www.nipic.com/show/1/47/7221511k2490d687.html'
queue.append(initialPage)
cnt = 0

#下载图片
def downloadPicture(url):
    print('download --> ' + url)
    pattern = r'/[^/]+?\.jpg'
    match = re.search(pattern, url)
    if match:
        filename = localSavePath + match.group()
        urllib.request.urlretrieve(url, filename)

while queue:
    url = queue.popleft()
    visited |= {url}

    print('cnt: ' + str(cnt) + '  <----  ' + url)
    cnt += 1

    #设置退出条件
    if cnt > 85:
        exit(0)

    try:
        urlop = urllib.request.urlopen(url, timeout=5)
    except:
        print('error open: ' + url)
        continue

    if 'html' not in urlop.getheader('Content-Type'):
        print('not html')
        continue

    try:
        data = urlop.read().decode('utf-8')
    except Exception as e:
        print(e)
        continue

    #for循环中给queue添加新链接,或者保存图片
    for item in re.findall('\"(.+?)\"', data):
        if re.match(r'http://.+?\.jpg', item):
            downloadPicture(item)
        elif 'http' in item and item not in visited:
            queue.append(item)

先到这里吧,留几个问题下次再解决:

  • 本例中只下了jpg图片,如果jpeg, png, gif等格式也要下,应该如何修改正则表达式?
  • 只有width > 400 and height > 400的图片才下载,该如何处理?
  • 写一个12306的登录程序
python爬虫与项目实战,网络爬虫是一个自动提取网页的程序,它为搜索引擎从万维网上下载网页,是搜索引擎的重要组成。 随着网络的迅速发展,万维网成为大量信息的载体,如何有效地提取并利用这些信息成为一个巨大的挑战。搜索引擎(Search Engine),例如传统的通用搜索引擎AltaVista,Yahoo!和Google等,作为一个辅助人们检索信息的工具成为用户访问万维网的入口和指南。但是,这些通用性搜索引擎也存在着一定的局限性,如: (1)不同领域、不同背景的用户往往具有不同的检索目的和需求,通用搜索引擎所返回的结果包含大量用户不关心的网页。 (2)通用搜索引擎的目标是尽可能大的网络覆盖率,有限的搜索引擎服务器资源与无限的网络数据资源之间的矛盾将进一步加深。 (3)万维网数据形式的丰富和网络技术的不断发展,图片、数据库、音频、视频多媒体等不同数据大量出现,通用搜索引擎往往对这些信息含量密集且具有一定结构的数据无能为力,不能很好地发现和获取。 (4)通用搜索引擎大多提供基于关键字的检索,难以支持根据语义信息提出的查询。 网络爬虫 为了解决上述问题,定向抓取相关网页资源的聚焦爬虫应运而生。聚焦爬虫是一个自动下载网页的程序,它根据既定的抓取目标,有选择的访问万维网上的网页与相关的链接,获取所需要的信息。与通用爬虫(general purpose web crawler)不同,聚焦爬虫并不追求大的覆盖,而将目标定为抓取与某一特定主题内容相关的网页,为面向主题的用户查询准备数据资源。 传统爬虫从一个或若干初始网页的URL开始,获得初始网页上的URL,在抓取网页的过程中,不断从当前页面上抽取新的URL放入队列,直到满足系统的一定停止条件。聚焦爬虫的工作流程较为复杂,需要根据一定的网页分析算法过滤与主题无关的链接,保留有用的链接并将其放入等待抓取的URL队列。然后,它将根据一定的搜索策略从队列中选择下一步要抓取的网页URL,并重复上述过程,直到达到系统的某一条件时停止。另外,所有被爬虫抓取的网页将会被系统存贮,进行一定的分析、过滤,并建立索引,以便之后的查询和检索;对于聚焦爬虫来说,这一过程所得到的分析结果还可能对以后的抓取过程给出反馈和指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值