Python爬虫教程002:urllib库基本使用

文章目录

    • [2.1 urllib基本使用](#2.1 urllib基本使用)
    • [2.2 urllib的1个类型6个方法](#2.2 urllib的1个类型6个方法)
    • [2.3 urllib下载](#2.3 urllib下载)

2.1 urllib基本使用

示例代码:

python 复制代码
# -*- coding: utf-8 -*-
# @Time: 2022/9/24 0024 9:47
# @Author: Wang
# @File: 01_urllib_基本使用.py

# 使用urllib来获取百度首页的源码
import urllib.request

# (1)定义一个url,就是你要访问的地址
url = 'http://www.baidu.com'

# (2)模拟浏览器向服务器发送请求
response = urllib.request.urlopen(url=url)

# (3)获取响应的页面源码
# read方法:返回的是字节形式的二进制数据
# 我们要将二进制的数据转换为字符串
# 二进制->字符串的动作:解码 decode('编码的格式')
content = response.read().decode('utf-8')

# (4)打印数据
print(content)

打印结果:

2.2 urllib的1个类型6个方法

python 复制代码
# -*- coding: utf-8 -*-
# @Time: 2022/9/24 0024 10:02
# @Author: Wang
# @File: 02_urllib_1个类型和6个方法.py

import urllib.request

url = 'http://www.baidu.com'

# 模拟浏览器向服务器发送请求
response = urllib.request.urlopen(url)

# 1个类型和6个方法
# response是HTTPResponse的类型
# print(type(response))

# 按照一个字节一个字节的去读
# content = response.read()
# print(content)

# 返回多少个字节
# content = response.read(5)
# print(content)

# 读取一行
# content = response.readline()
# print(content)

# 读取所有行
# content = response.readlines()
# print(content)

# 状态码
print(response.getcode())  # 200

# 请求url
print(response.geturl())  # http://www.baidu.com

# 状态信息
print(response.getheaders())

# 1个类型是HTTPResponse
# 6个方法 read readline readlines getcode geturl getheaders

2.3 urllib下载

下载网页

示例代码:

python 复制代码
import urllib.request

# 下载网页
url_page = 'http://www.baidu.com'

# url代表的是下载的路径 filename文件名
# 在python中,可以写变量的名字,也可以直接写值
urllib.request.urlretrieve(url_page, 'baidu.html')

运行结果:将爬取到的网页保存为baidu.html文件,可以直接通过浏览器打开,即是百度的首页。

下载图片

示例代码:

python 复制代码
# 下载图片
url_img = 'https://img2.baidu.com/it/u=1390544076,2637920000&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=625'

urllib.request.urlretrieve(url_img, 'lisa.jpg')

下载结果:

下载视频

python 复制代码
# 下载视频
url_vidio = 'https://vd2.bdstatic.com/mda-jmki3yf92d7w4ft9/v1-cae/sc/mda-jmki3yf92d7w4ft9.mp4?v_from_s=hkapp-haokan-hbf&auth_key=1664077962-0-0-93246b00edbdd7bda4482e4bbd5bc4d1&bcevod_channel=searchbox_feed&pd=1&cd=0&pt=3&logid=1362660174&vid=5104542693201134340&abtest=&klogid=1362660174'

urllib.request.urlretrieve(url_vidio, 'lisa.mp4')
相关推荐
Cuit小唐几秒前
C++ 状态模式详解
开发语言·c++·状态模式
AALoveTouch9 分钟前
大某麦演唱会门票如何自动抢
python
落羽的落羽26 分钟前
【落羽的落羽 C++】stack和queue、deque、priority_queue、仿函数
开发语言·c++
阿乾之铭34 分钟前
Java后端文件类型检测(防伪造)
java·开发语言
sunbyte41 分钟前
Three.js + React 实战系列 - 联系方式提交表单区域 Contact 组件✨(表单绑定 + 表单验证)
开发语言·javascript·react.js
(ღ星辰ღ)1 小时前
js应用opencv
开发语言·javascript·opencv
忧陌6061 小时前
Day22打卡-复习
python
HY小海1 小时前
【数据结构】双链表
c语言·开发语言·数据结构·学习
Go Dgg2 小时前
Go语言实现豆瓣电影Top250爬虫
开发语言·爬虫·golang
真的想上岸啊2 小时前
c语言第一个小游戏:贪吃蛇小游戏03
c语言·开发语言·算法