爬取网页的通用代码框架
2021-05-23 本文已影响0人
闲云野鹤_23dd
1、什么是网页的通用代码框架?
就是一组代码;能够准确的可靠地爬取网页上的内容。
2、网络的异常处理:
data:image/s3,"s3://crabby-images/28ecd/28ecd8098ecec77d7a3b0e478c31fdc429a20047" alt=""
注意:6、7的区别
data:image/s3,"s3://crabby-images/684c1/684c19143b8366cf0f869bde82a7e4af68671fee" alt=""
r.raise_for_status()使用方法:
data:image/s3,"s3://crabby-images/67521/67521cf95770601ec45d7a6a0265008b836abc01" alt=""
data:image/s3,"s3://crabby-images/3af2d/3af2dfabd0f48e9eee0375631c1efed35d86a2bf" alt=""
代码如下:
import requests
def getHTMLText(url):
try:
r=requests.get(url,timeout=30)
r.raise_for_status()#如果状态不是200,引发HTTPError异常
r.encoding=r.apparent_encoding#根据响应内容指定编码格式utf-8
return r.text
except:
return '产生异常'
if name == 'main':
url='https://www.baidu.com'
print(getHTMLText(url))
Http协议和Requests库的 方法:
http协议内容请参考:HTTP入门详解 - 简书 (jianshu.com)
是不是很熟悉,和request库的七个主要七个方法很像。
data:image/s3,"s3://crabby-images/c978a/c978afea755082c03cc440047233979a783de58a" alt=""
data:image/s3,"s3://crabby-images/272ac/272acca6e92e9c3003cc34173f7d3b5b8e503625" alt=""
head()方法更节省带宽:
data:image/s3,"s3://crabby-images/38593/385934f1c70fbe22845e8e512e92fe3d03600c8f" alt=""
data:image/s3,"s3://crabby-images/7ae30/7ae309b3028f9c44a188f6bc12c11e631d1febd3" alt=""
data:image/s3,"s3://crabby-images/408a7/408a753764bfb8120c3362b9a580892fb8ad3541" alt=""
put()与post()类似。