首页 > 其他 > 详细

爬虫 1

时间:2020-04-26 18:32:45      阅读:76      评论:0      收藏:0      [点我收藏+]

1. 使用requests 、urllib构建简单爬虫代码

"""爬取 唯美女生 网站图片"""
import requests
import re
import os
import time


# 1. 请求网页
myheaders = {User-Agent: Mozilla/5.0}
# url = "http://pic.netbian.com"
url = http://pic.netbian.com/4kmeinv
response = requests.get(url, headers=myheaders)

# 2. 处理响应数据, 正则匹配
html = response.text
img_urls = re.findall(<img src="(.*?)" alt=".*?">, html)
print(img_urls)

# 3. 下载图片
if not os.path.exists(彼岸图片):
    os.mkdir(彼岸图片)
for img_url in img_urls:
    time.sleep(1)
    img_name = img_url.split(/)[-1]
    response = requests.get((url + img_url), headers=myheaders)
    with open(彼岸图片/ + img_name, wb) as f:
        f.write(response.content)
"""使用 urllib 创建爬虫"""
from urllib.request import urlopen
from urllib.request import Request      # 包装爬虫


url = https://www.baidu.com

headers = {
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36

}
# 创建Resquest对象,来包装请求
request = Request(url, headers=headers, method=GET, data=None)
# 发送请求
response = urlopen(request)
# 打印信息
print(状态码:, response.getcode(), 真实请求地址:, response.geturl(), 状态码:, response.status, 请求头:, response.getheaders())
info = response.read().decode()
print(info)

 

2.  GET请求, 当需要手动传参时,可以使用urllib.parse中的:quote、urlencode来进行“中文”转码

"""GET 请求,当需要手动传参,且参数为中文时,需要将参数转码
    单个参数时可以使用:quote,转码
    多个参数时:urlencode, 转码
"""
from urllib.request import urlopen, Request
from urllib.parse import quote

# 单个参数时可以使用:quote,转码
# url = "https://www.baidu.com/s?wd={}".format(quote("科技"))
headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"
}
# request = Request(url, headers=headers)
# response = urlopen(request, timeout=3)
# info = response.read().decode()
# print(info)


# 多个参数时:urlencode, 转码
from urllib.parse import urlencode

args = {
    wd: "科技",
    ie: utf-8
    # ...
}

url = https://www.baidu.com/s?{}.format(urlencode(args))
print(url)

request2 = Request(url, headers=headers)
response2 = urlopen(request2, timeout=3)
info2 = response2.read().decode()
print(info2)

 

  

  

爬虫 1

原文:https://www.cnblogs.com/leafchen/p/12781421.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!