python爬虫代码示例-Python爬虫之urllib示例

1、最简单:直接抓取页面代码

import urllib.request

import urllib.error

url = 'http://test.com/test.html'

try:

resp = urllib.request.urlopen(url)

except urllib.error.HTTPError as e:

print(e.code, e.msg)

except urllib.error.URLError as e:

print(e.reason)

else:

result = resp.read().decode('utf-8')

print(result)

2、使用 Request

import urllib.request

import urllib.error

url = 'http://test.com/test.html'

try:

req = urllib.request.Request(url) # 构造一个Request对象,推荐

resp = urllib.request.urlopen(req)

except urllib.error.HTTPError as e:

print(e.code, e.msg)

except urllib.error.URLError as e:

print(e.reason)

else:

result = resp.read().decode('utf-8')

print(result)

3、发送数据,GET

import urlib.request

import urllib.parse

url = 'http://test.com/a.php?act=login&id=123'

req = urllib.request.Request(url)

resp = urllib.request.urlopen(req)

# or

url = 'http://test.com/a.php'

params = {

'act': 'login',

'id': 123,

'name': u'张三'

}

geturl = url + '?' + urllib.parse.urlencode(params)

req = urllib.request.Request(geturl)

resp = urllib.request.urlopen(req)

print(resp.read().decode('utf-8'))

# {"act":"login","name":"张三","id":"123"}

4、发送数据,POST

import urllib.request

import urllib.parse

url = 'http://test.com/a.php'

params = {

'act': 'login',

'login[name]': u'张三',

'login[password]': '123456'

}

data = urllib.parse.urlencode(params).encode('utf-8')

req = urllib.request.Request(url, data)

resp = urllib.request.urlopen(req)

print(resp.read().decode('utf-8'))

# {"act":"login","login":{"password":"123456","name":"张三"}}}

5、发送数据和header

import urllib.request

import urllib.parse

url = 'http://test.com/a.php'

params = {

'act': 'login',

'login[name]': u'张三',

'login[password]': '123456'

}

data = urllib.parse.urlencode(params).encode('utf-8')

headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) '

'Chrome/54.0.2840.99 Safari/537.36',

'Referer': 'http://www.baidu.com',

'haha': 'xixi'

}

req = urllib.request.Request(url, data, headers)

resp = urllib.request.urlopen(req)

print(resp.read().decode('utf-8'))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值