Pyhon 网络爬虫--简单的爬取功能

从网页上爬取内容大致分为三步:

1、获取整个网页信息(源代码) 

2、通过正则匹配,获取指定标签中的内容  

3、将获取到的内容写到本地中

一、获取整个网页信息(源代码)

# coding utf-8
import urllib.request

def getHtml(url):
    html = urllib.request.urlopen(url).read()
    return html

html = getHtml("http://www.weather.com.cn/weather/101190401.shtml")
print(html)
urllib.request.urlopen() 方法用于打开一个 URL 地址。
read()用于读取URL中的数据

二、通过正则匹配,获取指定标签中的内容

# coding utf-8
import urllib.request
import re
def getHtml(url):
    html = urllib.request.urlopen(url).read()
    return html
def getImg(html):
    reg = 'src="(.+?\.png)"'
    imgre = re.compile(reg)
    html = html.decode('utf-8')#不加这句话,否则会报TypeError: cannot use a string pattern on a bytes-like object错误
    imglist = imgre.findall(html)
    return imglist
html = getHtml("http://www.weather.com.cn/weather/101190401.shtml")
print(getImg(html))
(按F12打开开发者工具,在里面可以查看源代码,看你所需要筛选内容的格式)
通过正则表达式对html中进行筛选,获得图片链接
re.compile() 可以把正则表达式编译成一个正则表达式对象.
正则表达式对象.findall()  方法读取 html  中包含  imgre (正则表达式)的数据。

三、将页面筛选的数据保存到本地

# coding utf-8
import urllib.request
import re
def getHtml(url):
    html = urllib.request.urlopen(url).read()
    return html
def getImg(html):
    reg = 'src="(.+?\.png)"'
    imgre = re.compile(reg)
    html = html.decode('utf-8')
    imglist = imgre.findall(html)
    x = 0
    for imgurl in imglist:
        urllib.request.urlretrieve(imgurl, '%s.png' % x)
        x += 1
    return imglist
html = getHtml("http://www.weather.com.cn/weather/101190401.shtml")
print(getImg(html))
urllib.request.urlretrieve() 方法,直接将远程数据下载到本地。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值