Python의 requests는 웹 서버로 요청을 보내고 응답을 받는 데 사용되는 라이브러리입니다. requests를 사용하면 HTTP 요청을 보내고 응답을 받는 동작을 쉽게 구현할 수 있습니다.
1. requests 설치
requests는 pip를 이용하여 쉽게 설치할 수 있습니다.
pip install requests
파이썬에서 아래와 같이 모듈을 import하여 사용할 수 있습니다.
import requests
2. 테스트 웹 서버
requests를 사용해보려면 웹 서버가 필요한데, 아래와 같은 곳에서 테스트 웹 서버를 제공합니다.
3. GET 요청
어떤 URL의 데이터를 가져올 때 GET 요청을 보냅니다.
requests.get(URL)
으로 서버에 GET 요청을 보낼 수 있습니다. 리턴되는 값은 요청에 대한 응답이며, 아래와 같은 속성들이 있습니다.
status_code
: 응답 상태 (200: 성공, 404: 페이지를 찾을 수 없음, 500: 서버 오류 등등)text
: 응답 본문을 텍스트로 출력json
: 응답 본문을 JSON으로 파싱하여 파이썬 객체로 리턴
아래와 같이 GET 요청을 할 수 있습니다.
import requests
url = 'https://jsonplaceholder.typicode.com/posts/1'
r = requests.get(url)
print(r.status_code)
print(r.text)
print(r.json())
Output:
200
{
"userId": 1,
"id": 1,
"title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
"body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
}
{'userId': 1, 'id': 1, 'title': 'sunt aut facere repellat provident occaecati excepturi optio reprehenderit', 'body': 'quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto'}
Param과 함께 사용
https://jsonplaceholder.typicode.com/posts?userId=1
처럼 userId 1에 대해서만 데이터를 가져오려면, requests에서는 아래와 같이 params를 전달하면 됩니다.
params에 key-value를 입력하고, get()
의 두번째 인자로 전달합니다.
import requests
url = 'https://jsonplaceholder.typicode.com/posts'
params = {'userId': '1'}
r = requests.get(url, params)
print(r.status_code)
print(r.text)
Output:
200
[
{
"userId": 1,
"id": 1,
"title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
"body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
},
{
"userId": 1,
"id": 2,
"title": "qui est esse",
"body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
},
{
"userId": 1,
"id": 3,
"title": "ea molestias quasi exercitationem repellat qui ipsa sit aut",
"body": "et iusto sed quo iure\nvoluptatem occaecati omnis eligendi aut ad\nvoluptatem doloribus vel accusantium quis pariatur\nmolestiae porro eius odio et labore et velit aut"
},
{
"userId": 1,
"id": 4,
"title": "eum et est occaecati",
"body": "ullam et saepe reiciendis voluptatem adipisci\nsit amet autem assumenda provident rerum culpa\nquis hic commodi nesciunt rem tenetur doloremque ipsam iure\nquis sunt voluptatem rerum illo velit"
},
{
"userId": 1,
"id": 5,
"title": "nesciunt quas odio",
"body": "repudiandae veniam quaerat sunt sed\nalias aut fugiat sit autem sed est\nvoluptatem omnis possimus esse voluptatibus quis\nest aut tenetur dolor neque"
},
{
"userId": 1,
"id": 6,
"title": "dolorem eum magni eos aperiam quia",
"body": "ut aspernatur corporis harum nihil quis provident sequi\nmollitia nobis aliquid molestiae\nperspiciatis et ea nemo ab reprehenderit accusantium quas\nvoluptate dolores velit et doloremque molestiae"
},
{
"userId": 1,
"id": 7,
"title": "magnam facilis autem",
"body": "dolore placeat quibusdam ea quo vitae\nmagni quis enim qui quis quo nemo aut saepe\nquidem repellat excepturi ut quia\nsunt ut sequi eos ea sed quas"
},
{
"userId": 1,
"id": 8,
"title": "dolorem dolore est ipsam",
"body": "dignissimos aperiam dolorem qui eum\nfacilis quibusdam animi sint suscipit qui sint possimus cum\nquaerat magni maiores excepturi\nipsam ut commodi dolor voluptatum modi aut vitae"
},
{
"userId": 1,
"id": 9,
"title": "nesciunt iure omnis dolorem tempora et accusantium",
"body": "consectetur animi nesciunt iure dolore\nenim quia ad\nveniam autem ut quam aut nobis\net est aut quod aut provident voluptas autem voluptas"
},
{
"userId": 1,
"id": 10,
"title": "optio molestias id quia eum",
"body": "quo et expedita modi cum officia vel magni\ndoloribus qui repudiandae\nvero nisi sit\nquos veniam quod sed accusamus veritatis error"
}
]
4. POST 요청
신규 데이터를 저장할 때 POST 요청을 보냅니다.
POST 요청은 아래와 같이 보낼 수 있습니다.
- 저장하려는 데이터를 data 인자로 전달
- 데이터 저장 성공 시,
status_code
201(Created), 200(OK) 같은 값들이 전달됨
import requests
import json
url = 'https://jsonplaceholder.typicode.com/posts'
headers = {'Content-type': 'application/json; charset=utf-8'}
data = {'title': 'foo', 'body': 'bar', 'userId': '1'}
r = requests.post(url, headers=headers, data=json.dumps(data))
print(r.status_code)
print(r.text)
Output:
201
{
"title": "foo",
"body": "bar",
"userId": "1",
"id": 101
}
5. PUT 요청
서버에 저장된 데이터의 속성들을 모두 변경할 때 PUT 요청을 보냅니다.
아래 코드는 URL 데이터의 모든 속성들을 변경합니다.
- 성공하면 변경된 데이터가 결과로 전달됨
import requests
import json
url = 'https://jsonplaceholder.typicode.com/posts/1'
headers = {'Content-type': 'application/json; charset=utf-8'}
data = {'id': '1', 'title': 'foo', 'body': 'bar', 'userId': '1'}
r = requests.put(url, headers=headers, data=json.dumps(data))
print(r.status_code)
print(r.text)
Output:
200
{
"id": 1,
"title": "foo",
"body": "bar",
"userId": "1"
}
6. PATCH 요청
기존 데이터에서 일부를 변경할 때 PATCH 요청을 보냅니다.
아래 코드는 PATCH 요청을 보내서 ~/posts/1
의 데이터의 title
만 foo
로 변경합니다.
- data 인자로 변경하려는 속성과 값만 전달
- 성공하면, 변경된 데이터가 전달됨
import requests
import json
url = 'https://jsonplaceholder.typicode.com/posts/1'
headers = {'Content-type': 'application/json; charset=utf-8'}
data = {'title': 'foo'}
r = requests.patch(url, headers=headers, data=json.dumps(data))
print(r.status_code)
print(r.text)
Output:
200
{
"userId": 1,
"id": 1,
"title": "foo",
"body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
}
PUT과 PATCH의 차이점은, PUT은 데이터 전체 속성을 변경하는데 사용되고 PATCH는 데이터 일부 속성만 변경할 때 사용됩니다.
7. DELETE 요청
데이터를 삭제할 때 DELETE 요청을 보냅니다.
아래 코드는 URL에 대한 데이터를 삭제합니다.
- 삭제되면 text로 empty가 전달됨
import requests
url = 'https://jsonplaceholder.typicode.com/posts/1'
headers = {'Content-type': 'application/json; charset=utf-8'}
data = {'title': 'foo'}
r = requests.delete(url)
print(r.status_code)
print(r.text)
Output:
200
{}
Related Posts
- Python - Yaml 파일 파싱하는 방법
- Python - 파일 내용 삭제
- Python - for문에서 리스트 순회 중 요소 값 제거
- Python - 두 리스트에서 공통 요소 값 찾기
- Python - 문자열 앞(뒤)에 0으로 채우기
- Python - 공백으로 문자열 분리
- Python - 중첩 리스트 평탄화(1차원 리스트 변환)
- Python - 16진수 문자열을 Int로 변환
- Python - 두 날짜, 시간 비교
- Python f-string으로 변수 이름, 값 쉽게 출력 (변수명 = )
- Python - nonlocal과 global 사용 방법
- Python 바다코끼리 연산자 := 알아보기
- Python - pip와 requirements.txt로 패키지 관리
- Python - 딕셔너리 보기 좋게 출력 (pprint)
- Python - Requests 사용 방법 (GET/POST/PUT/PATCH/DELETE)
- Python - 온라인 컴파일러 사이트 추천
- Python - os.walk()를 사용하여 디렉토리, 파일 탐색
- Python - 문자열 비교 방법
- Python - Text 파일 읽고 쓰는 방법 (read, write, append)
- Python - 리스트에서 첫번째, 마지막 요소 가져오는 방법
- Python - 두개의 리스트 하나로 합치기
- Python - 리스트의 마지막 요소 제거
- Python - 리스트의 첫번째 요소 제거
- Python 소수점 버림, 4가지 방법
- Python 코드 안에서 버전 확인 방법
- Python 소수점 반올림, round() 예제
- Python - 리스트 평균 구하기, 3가지 방법
- Python - bytes를 String으로 변환하는 방법
- Python - String을 bytes로 변환하는 방법
- Python 버전 확인 방법 (터미널, cmd 명령어)
- Python - 람다(Lambda) 함수 사용 방법
- Python - dict 정렬 (Key, Value로 sorting)
- Python - range() 사용 방법 및 예제
- Python - 리스트를 문자열로 변환
- Python - 문자를 숫자로 변환 (String to Integer, Float)