Python クローラーを使用する場合は、ネットワーク リクエストの開始をシミュレートする必要があります。使用される主なライブラリは、リクエスト ライブラリとPython ビルトイン urllib ライブラリの場合、通常、urllib を再カプセル化したリクエストを使用することをお勧めします。
これらの違いは何ですか?
以下では、それらの使用上の主な違いを理解するために、ケースについて詳しく説明します。
はじめに:urllib ライブラリの応答オブジェクトは、最初に http オブジェクトと request オブジェクトを作成し、次にロードします。それらを reques.urlopen.http リクエストに追加します。
返されるのは http、応答オブジェクトであり、実際には html 属性です。 .read().decode()を使用してデコードし、str文字列型に変換すると、中国語の文字が表示できるようになります。
#例:from urllib import request #请求头 headers = { "User-Agent": 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.186 Safari/537.36' } wd = {"wd": "中国"} url = "http://www.baidu.com/s?" req = request.Request(url, headers=headers) response = request.urlopen(req) print(type(response)) print(response) res = response.read().decode() print(type(res)) print(res)
##実行結果:
注:
通常、http を構築するときは Web ページをクロールします。リクエストの場合は、Useragent、Cookie などの追加情報を追加するか、プロキシ サーバーを追加する必要があります。多くの場合、これらは必要なクロール防止メカニズムです。简介:requests库调用是requests.get方法传入url和参数,返回的对象是Response对象,打印出来是显示响应状态码。 通过.text 方法可以返回是unicode 型的数据,一般是在网页的header中定义的编码形式,而content返回的是bytes,二级制型的数据,还有 .json方法也可以返回json字符串。 如果想要提取文本就用text,但是如果你想要提取图片、文件等二进制文件,就要用content,当然decode之后,中文字符也会正常显示。 requests的优势:Python爬虫时,更建议用requests库。因为requests比urllib更为便捷,requests可以直接构造get,post请求并发起,而urllib.request只能先构造get,post请求,再发起。 例: 运行结果 (可以直接获取整网页的信息,打印控制台): 1. 本文基于Python基础,主要介绍了urllib库和requests库的区别。 2. 在使用urllib内的request模块时,返回体获取有效信息和请求体的拼接需要decode和encode后再进行装载。进行http请求时需先构造get或者post请求再进行调用,header等头文件也需先进行构造。 3. requests是对urllib的进一步封装,因此在使用上显得更加的便捷,建议在实际应用当中尽量使用requests。 4. 希望能给一些对爬虫感兴趣,有一个具体的概念。方法只是一种工具,试着去爬一爬会更容易上手,网络也会有很多的坑,做爬虫更需要大量的经验来应付复杂的网络情况。 5. 希望大家一起探讨学习, 一起进步。 以上がPython の urllib ライブラリと request ライブラリの違いを理解するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。三、requests库
import requests
headers = {
"User-Agent": "Mozilla/5.0 (Linux; U; Android 8.1.0; zh-cn; BLA-AL00 Build/HUAWEIBLA-AL00) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/57.0.2987.132 MQQBrowser/8.9 Mobile Safari/537.36"
}
wd = {"wd": "中国"}
url = "http://www.baidu.com/s?"
response = requests.get(url, params=wd, headers=headers)
data = response.text
data2 = response.content
print(response)
print(type(response))
print(data)
print(type(data))
print(data2)
print(type(data2))
print(data2.decode())
print(type(data2.decode()))
四、总结