Python의 CURL 대안


114

PHP에서 사용하는 cURL 호출이 있습니다.

curl -i -H '수락 : application / xml'-u login : key " https://app.streamsend.com/emails "

파이썬에서 똑같은 일을 할 방법이 필요합니다. Python에서 cURL에 대한 대안이 있습니까? 나는 urllib에 대해 알고 있지만 Python 멍청이이며 사용 방법을 모릅니다.



2
urllib2는 이러한 종류의 작업에 널리 사용되는 패키지입니다.
Saurav


3
위는 requestsPython에서 간단한 http를 수행 할 수있는 훌륭한 라이브러리 링크입니다 (PyPi에서 easy_install 또는 pip를 통해 설치할 수 있음). 이름 / URL은 약간 혼란 스럽습니다. 처음에는 이것이 더 나은 것을위한 위시리스트 요청이라고 생각했습니다 urllib2. 대신 사용 requests하기 매우 직관적 인 Pythonic 라이브러리 sudo easy_install requests또는 sudo pip install requests.
jimbob 박사는

PyCurl 성능 대 파이썬 요청 귀하의 요구 사항에 괜찮은 당신
Santhosh

답변:


68
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']

대신 urllib2를 사용하여 cURL 호출. 완전히 테스트되지 않았습니다.


4
이것을 바로 아래 답변과 비교하고 지난 4 년 동안 파이썬이 얼마나 발전했는지 확인하는 것이 좋습니다
Razi Shaban

133

요청 : 인간을위한 HTTP 사용자 가이드에 설명 된 HTTP 요청을 사용할 수 있습니다 .


2
요청은 최신이며 가장 큰 것입니다! 그것은 연기와 서투른 urllib2가를 화상, 내가 요청을 할 파이썬 들어오는 3.X 버전에 대한 표준 HTTP 클라이언트가된다
Phyo Arkar Lwin

1
요청을 사용하도록 전환했을 때 더 이상 urllib2를 직접 사용하는 것을 다시 보지 않았습니다. 내장 된 JSON 디코딩도 편리합니다. 적절한 콘텐츠 유형이 설정된 경우 json으로 본문을 수동으로로드 할 필요가 없습니다.
Thomas Farvour

요청은 매우 간단합니다. 몇 분만에 사용자 지정 인증 체계를 만들 수도있었습니다. urllib2는 매우 짜증납니다.
Doug

35

다음은 GitHub의 API에 대한 기본 인증을 수행하는 urllib2를 사용하는 간단한 예제입니다.

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 요청 만 지원한다는 것입니다.
DELETE, PUT 등과 같은 다른 HTTP 동사를 사용해야하는 경우 PYCURL을 살펴보고 싶을 것입니다.


왜 이것이 투표를 거부 했습니까? PycURL 대신 PYCURL을 작성했기 때문일 수 있습니다. : D
Bhargav Rao

20

이렇게 curl을 호출하는 명령을 사용하는 경우 Python에서 subprocess. 예:

subprocess.call(['curl', '-i', '-H', '"Accept: application/xml"', '-u', 'login:key', '"https://app.streamsend.com/emails"'])

또는 PHP가 가지고있는 것과 같은보다 구조화 된 API로 사용하고 싶다면 PycURL을 사용해 볼 수 있습니다.


아니요. cURL 호출은 프로그램의 일부입니다. 위의 curl 호출에서 똑같은 작업을 수행하는 코드를 게시 할 수 있다면 좋을 것입니다.
Gaurav Sharma

귀하의 질문에 따라 하위 프로세스를 사용하여 의미하는 바의 예를 추가했지만 PycURL과 같은 것을 찾고 있다고 생각합니다.
unholysampler

나는 이것이 오래되었다는 것을 알고 있지만 PycURL은 내 생각에 대부분의 cURL 사용에 대해 매우 낮은 수준입니다. cURL의 PHP 구현조차도 상당히 낮은 수준입니다.
Thomas Farvour

cmd에서 "python"을 호출하여 파이썬 환경에있는 후 "이름 오류, 이름 하위 프로세스가 정의되지 않음"이 발생합니다.
Timo

@ 티모 당신은 import subprocess? python repl 환경은 python 파일과 같으므로 다른 모듈을 가져와야합니다.
unholysampler 2014-06-07

13
import requests

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

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

이것은 내가 얻을 수 있었던 가장 간단한 것입니다.


이것이 가장 간단한 대답입니다! urllib2지나치게 복잡합니다.
not2qubit

7

몇 가지 예, 설탕 구문과 함께 urllib를 사용하는 방법. 요청 및 기타 라이브러리에 대해 알고 있지만 urllib는 파이썬의 표준 lib이며 별도로 설치할 필요가 없습니다.

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 링크입니다. 현재 지원 :

  • 권한 부여

  • CRUD 호환

  • 자동 문자 집합 감지

  • 자동 인코딩 (압축) 감지


4

찾고있는 명령 줄에서 위의 모든 것을 실행하는 경우 HTTPie를 권장 합니다 . 이 환상적인 컬의 대안이고 아주 쉽게 그리고 편리하게 사용 (및 사용자 정의)에.

다음 은 GitHub 의 (간결하고 정확한) 설명입니다.

HTTPie (aych-tee-tee-pie로 발음)는 명령 줄 HTTP 클라이언트입니다. 목표는 CLI와 웹 서비스 간의 상호 작용을 최대한 인간 친화적으로 만드는 것입니다.

간단하고 자연스러운 구문을 사용하여 임의의 HTTP 요청을 보낼 수있는 간단한 http 명령을 제공하고 색상 화 된 출력을 표시합니다. HTTPie는 테스트, 디버깅 및 일반적으로 HTTP 서버와 상호 작용하는 데 사용할 수 있습니다.


인증 관련 문서 는 문제를 해결하는 데 충분한 지침을 제공해야합니다. 물론 위의 모든 답변도 정확하며 동일한 작업을 수행하는 다른 방법을 제공합니다.


따라서 Stack Overflow에서 멀어 질 필요가 없습니다. 여기에 요약 된 내용이 있습니다.

Basic auth:

$ http -a username:password example.org
Digest auth:

$ http --auth-type=digest -a username:password example.org
With password prompt:

$ http -a username example.org


아마 나는 그것을 전혀 얻지 못했지만 파이썬 모듈입니까? 셸 / CLI 도구 인 것 같고 실망 스럽습니다. '(사용하기가 너무 쉬워 보였습니다
Alex

@Alex-Python 모듈입니다. Github의 README ( github.com/jkbrzt/httpie )에는 필요한 모든 것이 포함되어 있습니다.
stuxnetting
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.