requests中get和post传参

get请求

get(url, params=None, **kwargs)

requests实现get请求传参的两种方式

方式一:

import requests

url = 'http://www.baidu.com/s?wd=python'  # 使用?携带参数
r = requests.get(url)
print(r.url)

执行结果:
	http://www.baidu.com/s?wd=python

方式二:

import requests

url = 'http://www.baidu.com/s'  
params = {'wd': 'python'}  # 也可以将携带的参数传给params
r = requests.get(url, params=params)
print(r.url)

执行结果:
	http://www.baidu.com/s?wd=python

推荐使用第一种方式,代码简洁,如果需要参数化url中的参数可以参照如下方式:

import requests

lists = ['python', 'php', 'Java']

for i in lists:
    url = 'http://www.baidu.com/s?wd=%s' % (str(i))
    r = requests.get(url)
    print(r.url)

执行结果:
	http://www.baidu.com/s?wd=python
	http://www.baidu.com/s?wd=php
	http://www.baidu.com/s?wd=Java

post请求

post(url, data=None, json=None, **kwargs)

post请求是我们常说的提交表单,表单的数据内容就是post请求的参数,request实现post请求需设置请求参数data,数据格式可以为字典、元组、列表和json格式,不同数据格式有不同的优势。

示例代码:

import requests
# import json

"""
字典转json方法
data = {'key1': '1', 'key2': '2'}
data = json.dumps(data)
"""

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

r = requests.post(url, data=data)  # 使用data携带参数
print(r.text)

data是发送请求到网站(服务器)的数据。

注意:requests的get和post方法的请求参数分别是params 和 data,不要混淆两者的使用要求。

获取相应内容

  • r.status_code:响应状态码
  • r.raw:原始响应体,使用r.raw.read()读取
  • r.content:字节方式的响应体,需要进行解码
  • r.text:字符串方式的响应体,会自动更具响应头部的字符编码进行解码
  • r.headers:以字典对象储存服务器响应头,但是这个字典比较特殊,字典键不区分大小写,若键不存在,则返回None
  • r.json():request中内置的json解码器
  • r.raise_for_status():请求失败(非200响应),抛出异常
  • r.url:获取请求的url
  • r.cookies:获取请求后的cookies
  • r.encoding:获取编码格式

转载于:https://www.cnblogs.com/weibgg/p/10786986.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值