爬虫-urllib2-Headers (常用)

本文介绍了爬虫中User-Agent的作用及常见浏览器的User-Agent字符串,包括PC端与移动端,并提供了Python示例代码来模拟不同浏览器进行网页抓取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

爬虫---学习笔记

爬虫请求网站时要模拟浏览器,这就要用到User-Agent


#PC端
UserAgent = {
"safari 5.1 – MAC":"User-Agent:Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10_6_8; en-us) AppleWebKit/534.50 (KHTML, like Gecko) Version/5.1 Safari/534.50",
"safari 5.1 – Windows":"User-Agent:Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us) AppleWebKit/534.50 (KHTML, like Gecko) Version/5.1 Safari/534.50",
"IE 9.0":"User-Agent:Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0);",
"IE 8.0":"User-Agent:Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0; Trident/4.0)",
"IE 7.0":"User-Agent:Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)",
"IE 6.0":"User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)",
"Firefox 4.0.1 – MAC":"User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:2.0.1) Gecko/20100101 Firefox/4.0.1",
"Firefox 4.0.1 – Windows":"User-Agent:Mozilla/5.0 (Windows NT 6.1; rv:2.0.1) Gecko/20100101 Firefox/4.0.1",
"Opera 11.11 – MAC":"User-Agent:Opera/9.80 (Macintosh; Intel Mac OS X 10.6.8; U; en) Presto/2.8.131 Version/11.11",
"Opera 11.11 – Windows":"User-Agent:Opera/9.80 (Windows NT 6.1; U; en) Presto/2.8.131 Version/11.11",
"Chrome 17.0 – MAC":"User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_0) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.56 Safari/535.11",
"Maxthon":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Maxthon 2.0)",
"Tencent TT":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; TencentTraveler 4.0)",
"The World 2.x":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1)",
"The World 3.x":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; The World)",
"sogou 1.x":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; SE 2.X MetaSr 1.0; SE 2.X MetaSr 1.0; .NET CLR 2.0.50727; SE 2.X MetaSr 1.0)",
"360":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; 360SE)",
"Avant":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Avant Browser)",
"Green Browser":"User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1)"
}


#phone
UserAgent = {
"iOS 4.33 – iPhone":"User-Agent:Mozilla/5.0 (iPhone; U; CPU iPhone OS 4_3_3 like Mac OS X; en-us) AppleWebKit/533.17.9 (KHTML, like Gecko) Version/5.0.2 Mobile/8J2 Safari/6533.18.5",
"iOS 4.33 – iPod Touch":"User-Agent:Mozilla/5.0 (iPod; U; CPU iPhone OS 4_3_3 like Mac OS X; en-us) AppleWebKit/533.17.9 (KHTML, like Gecko) Version/5.0.2 Mobile/8J2 Safari/6533.18.5",
"iOS 4.33 – iPad":"User-Agent:Mozilla/5.0 (iPad; U; CPU OS 4_3_3 like Mac OS X; en-us) AppleWebKit/533.17.9 (KHTML, like Gecko) Version/5.0.2 Mobile/8J2 Safari/6533.18.5",
"Android N1":"User-Agent: Mozilla/5.0 (Linux; U; Android 2.3.7; en-us; Nexus One Build/FRF91) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1",
"Android QQ":"User-Agent: MQQBrowser/26 Mozilla/5.0 (Linux; U; Android 2.3.7; zh-cn; MB200 Build/GRJ22; CyanogenMod-7) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1",
"Android Opera ":"User-Agent: Opera/9.80 (Android 2.3.4; Linux; Opera Mobi/build-1107180945; U; en-GB) Presto/2.8.149 Version/11.10",
"Android Pad Moto Xoom":"User-Agent: Mozilla/5.0 (Linux; U; Android 3.0; en-us; Xoom Build/HRI39) AppleWebKit/534.13 (KHTML, like Gecko) Version/4.0 Safari/534.13",
"BlackBerry":"User-Agent: Mozilla/5.0 (BlackBerry; U; BlackBerry 9800; en) AppleWebKit/534.1+ (KHTML, like Gecko) Version/6.0.0.337 Mobile Safari/534.1+",
"WebOS HP Touchpad":"User-Agent: Mozilla/5.0 (hp-tablet; Linux; hpwOS/3.0.0; U; en-US) AppleWebKit/534.6 (KHTML, like Gecko) wOSBrowser/233.70 Safari/534.6 TouchPad/1.0",
"Nokia N97":"User-Agent: Mozilla/5.0 (SymbianOS/9.4; Series60/5.0 NokiaN97-1/20.0.019; Profile/MIDP-2.1 Configuration/CLDC-1.1) AppleWebKit/525 (KHTML, like Gecko) BrowserNG/7.1.18124",
"Windows Phone Mango":"User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows Phone OS 7.5; Trident/5.0; IEMobile/9.0; HTC; Titan)",
"UC":"User-Agent: UCWEB7.0.2.37/28/999",
"UC standard":"User-Agent: NOKIA5700/ UCWEB7.0.2.37/28/999",
"UCOpenwave":"User-Agent: Openwave/ UCWEB7.0.2.37/28/999",
"UC Opera":"User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; ) Opera/UCWEB7.0.2.37/28/999"
}



利用构建好的userAgents.py文件来充当爬虫请求头

#!/usr/bin/env python
#-*- coding: utf-8 -*-

import urllib2
import userAgents
'''userAgents.py是个自定义的模块,位置处于当前目录下 '''

class Urllib2ModifyHeader(object):
	'''使用urllib2模块修改header '''
	def __init__(self):
		#  PC  User-Agent
		PCUA = userAgents.UserAgent.get('IE 9.0')
		#  Mobile  User-Agent
		MBUA = userAgents.UserAgent.get('UC standard')
		#测试用的网站选择的是有道翻译
		self.url = 'http://fanyi.youdao.com'

		self.useUserAgent(PCUA,1)
		self.useUserAgent(MBUA,2)

	def useUserAgent(self,userAgent,name):
		request = urllib2.Request(self.url)
		request.add_header(userAgent.split(':')[0],userAgent.split(':')[1])
		response = urllib2.urlopen(request)
		fileName = str(name) + '.html'
		with open(fileName,'a') as fp:
			fp.write("%s\n\n" %userAgent)
			fp.write(response.read())

if __name__ == '__main__':
	umh = Urllib2ModifyHeader()


同一网站会给不同的浏览器返回不同的内容,使用网络爬虫时尽可能的添加一个固定的User-Agent



### 使用 `urllib` 实现有道翻译爬虫 为了通过 Python 的 `urllib` 库实现有道翻译的功能,可以按照如下方式构建程序。此过程涉及向有道翻译的 API 发送 POST 请求并解析返回的 JSON 数据。 #### 导入必要的库 首先需要导入用于网络请求以及处理 URL 编码和解码的相关模块: ```python import urllib.request import urllib.parse import json ``` #### 设置目标URL与表单数据 定义好要访问的目标地址(即有道翻译接口),并将待翻译的文字作为参数传递给服务器。注意这里使用的是POST方法提交数据[^5]。 ```python url = 'http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule' form_data = { "i": "hello", # 这里替换为你想要翻译的内容 "from": "AUTO", "to": "AUTO", "doctype": "json" } ``` #### 对表单数据进行编码 由于 HTTP 协议规定,在发送之前必须先对这些键值对形式的数据做适当转换,使之成为适合传输的形式——通常采用 application/x-www-form-urlencoded 类型。这可以通过调用 `urllib.parse.urlencode()` 函数完成,并将其结果转化为字节流以便后续操作[^4]。 ```python data = bytes(urllib.parse.urlencode(form_data), encoding='utf8') ``` #### 创建Request对象并向服务器发起请求 创建一个 Request 对象指定完整的请求信息,包括头部字段等;接着利用 `urllib.request.urlopen()` 方法执行实际的HTTP请求动作[^2]。 ```python headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'} req = urllib.request.Request(url=url, data=data, headers=headers) response = urllib.request.urlopen(req) ``` #### 解析响应内容 最后一步是从接收到的信息中提取有用的部分。对于本案例而言,就是读取出JSON字符串表示的对象结构体中的具体翻译结果[^1]。 ```python content = response.read().decode('utf-8') json_result = json.loads(content) print(json_result['translateResult'][0][0]['tgt']) ``` 以上代码展示了如何基于Python标准库之一—`urllib` 来模拟浏览器行为从而获取在线翻译服务所提供的译文输出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值