Python中的CURL替换

Python中的CURL替换,python,curl,Python,Curl,我在PHP中使用了一个cURL调用: curl-i-H'Accept:application/xml'-u login:key“” 我需要一种用Python做同样事情的方法。Python中是否有cURL的替代方法。我知道urllib,但我是一个Python noob,不知道如何使用它。如果您使用一个命令来像那样调用curl,那么您可以在Python中使用子进程做同样的事情。例如: subprocess.call(['curl', '-i', '-H', '"Accept: application

我在PHP中使用了一个cURL调用:

curl-i-H'Accept:application/xml'-u login:key“”


我需要一种用Python做同样事情的方法。Python中是否有cURL的替代方法。我知道urllib,但我是一个Python noob,不知道如何使用它。

如果您使用一个命令来像那样调用curl,那么您可以在Python中使用
子进程做同样的事情。例如:

subprocess.call(['curl', '-i', '-H', '"Accept: application/xml"', '-u', 'login:key', '"https://app.streamsend.com/emails"'])
或者,如果您想让它成为一个更结构化的api,比如PHP,您也可以尝试一下

import urllib2

manager = urllib2.HTTPPasswordMgrWithDefaultRealm()
manager.add_password(None, 'https://app.streamsend.com/emails', 'login', 'key')
handler = urllib2.HTTPBasicAuthHandler(manager)

director = urllib2.OpenerDirector()
director.add_handler(handler)

req = urllib2.Request('https://app.streamsend.com/emails', headers = {'Accept' : 'application/xml'})

result = director.open(req)
# result.read() will contain the data
# result.info() will contain the HTTP headers

# To get say the content-length header
length = result.info()['Content-Length']

您的cURL调用改为使用urllib2。完全未经测试。

下面是一个使用urllib2的简单示例,它对GitHub的API进行基本身份验证

import urllib2

u='username'
p='userpass'
url='https://api.github.com/users/username'

# simple wrapper function to encode the username & pass
def encodeUserData(user, password):
    return "Basic " + (user + ":" + password).encode("base64").rstrip()

# create the request object and set some headers
req = urllib2.Request(url)
req.add_header('Accept', 'application/json')
req.add_header("Content-type", "application/x-www-form-urlencoded")
req.add_header('Authorization', encodeUserData(u, p))
# make the request and print the results
res = urllib2.urlopen(req)
print res.read()
此外,如果将其封装在脚本中并从终端运行,则可以将响应字符串管道化到“mjson.tool”以启用漂亮的打印

>> basicAuth.py | python -mjson.tool
最后需要注意的是,urllib2仅支持GET和POST请求。

如果您需要使用其他HTTP动词,如DELETE、PUT等,您可能需要查看

,您可以使用《用户指南》中描述的HTTP请求

import requests

url = 'https://example.tld/'
auth = ('username', 'password')

r = requests.get(url, auth=auth)
print r.content

这是我所能得到的最简单的一个例子。

一些例子,如何使用urllib实现这一点,以及一些简单的语法。我知道请求和其他库,但urllib是python的标准库,不需要单独安装任何东西

Python 2/3兼容

import sys
if sys.version_info.major == 3:
  from urllib.request import HTTPPasswordMgrWithDefaultRealm, HTTPBasicAuthHandler, Request, build_opener
  from urllib.parse import urlencode
else:
  from urllib2 import HTTPPasswordMgrWithDefaultRealm, HTTPBasicAuthHandler, Request, build_opener
  from urllib import urlencode


def curl(url, params=None, auth=None, req_type="GET", data=None, headers=None):
  post_req = ["POST", "PUT"]
  get_req = ["GET", "DELETE"]

  if params is not None:
    url += "?" + urlencode(params)

  if req_type not in post_req + get_req:
    raise IOError("Wrong request type \"%s\" passed" % req_type)

  _headers = {}
  handler_chain = []

  if auth is not None:
    manager = HTTPPasswordMgrWithDefaultRealm()
    manager.add_password(None, url, auth["user"], auth["pass"])
    handler_chain.append(HTTPBasicAuthHandler(manager))

  if req_type in post_req and data is not None:
    _headers["Content-Length"] = len(data)

  if headers is not None:
    _headers.update(headers)

  director = build_opener(*handler_chain)

  if req_type in post_req:
    if sys.version_info.major == 3:
      _data = bytes(data, encoding='utf8')
    else:
      _data = bytes(data)

    req = Request(url, headers=_headers, data=_data)
  else:
    req = Request(url, headers=_headers)

  req.get_method = lambda: req_type
  result = director.open(req)

  return {
    "httpcode": result.code,
    "headers": result.info(),
    "content": result.read()
  }


"""
Usage example:
"""

Post data:
  curl("http://127.0.0.1/", req_type="POST", data='cascac')

Pass arguments (http://127.0.0.1/?q=show):
  curl("http://127.0.0.1/", params={'q': 'show'}, req_type="POST", data='cascac')

HTTP Authorization:
  curl("http://127.0.0.1/secure_data.txt", auth={"user": "username", "pass": "password"})
函数不完整,也可能不理想,但显示了一个基本的表示和使用的概念。其他的东西可以根据口味添加或改变

12/08更新

是指向实时更新源的GitHub链接。 目前支持:

  • 授权书

  • 积垢兼容

  • 自动字符集检测

  • 自动编码(压缩)检测


如果它从您要查找的命令行运行上述所有功能,那么我建议您使用它。这是一个奇妙的卷发替代品,使用(和定制)超级简单方便

以下是GitHub对其(简洁而精确)的描述

HTTPie(发音为aych-tee-pie)是一个命令行HTTP客户端。 其目标是将CLI与web服务交互作为 尽量人性化

它提供了一个简单的http命令,允许发送任意消息 HTTP请求使用简单自然的语法,并显示 彩色输出。HTTPie可用于测试、调试和测试 通常与HTTP服务器交互


有关的文档应为您提供足够的解决问题的指针。当然,以上所有答案都是准确的,并且提供了完成同一任务的不同方法


为了避免堆栈溢出,这里简单介绍一下它提供的功能

Basic auth:
$http-用户名:password example.org
摘要授权:
$http--auth type=digest-a用户名:password example.org
在密码提示下:

$http-用户名example.org
No。cURL调用是程序的一部分。如果您可以发布与上面的curl调用完全相同的代码,那就太好了。根据您的问题添加了一个示例,说明了我所说的使用子流程的意思,但我猜您正在寻找更像PycURL的东西。我知道这比较旧,但在我看来,PycURL在大多数情况下的使用水平都很低。即使是cURL的PHP实现也是相当低级的。在从cmd调用“python”之后,我得到了“name error,name subprocess not defined”,因此处于python环境中。@Timo您是否
导入了subprocess
?python repl环境就像一个python文件,您必须导入其他模块。您可以尝试urllib2是一个广泛用于此类工作的软件包。更好的是:上面是一个伟大的库的链接,它可以在python中执行简单的http
请求
(可通过easy_install或PyPi中的pip进行安装)。名称/URL有点让人困惑——起初我几乎认为这是一个更好的
urlib2
的愿望列表请求,而不是
requests
一个非常直观易用的pythonic库
sudo easy\u install requests
sudo pip install requests
。你的要求是最新最棒的!它冒烟燃烧着笨拙的urllib2,我希望请求成为python传入3.x版本的标准HTTP客户端当我切换到使用请求时,我再也不会直接使用urllib2了。内置的JSON解码也很方便。如果设置了适当的内容类型,则无需手动加载带有json的正文。请求非常简单。我甚至可以在几分钟内创建一个自定义身份验证方案。urllib2非常烦人。很高兴将其与下面的答案进行比较,看看Python在过去四年中取得了多大的进步。为什么会被否决?也许是因为您编写了PYCURL而不是PYCURL:Dmaybe,我根本就没有理解它,但它是Python模块吗?我猜它是一个shell/CLI工具,我不同意:'(它看起来很容易use@Alex-这是一个Python模块。Github()上的自述文件包含您需要的所有内容。这是最简单的答案!
urllib2
过于复杂。