Develop/FastAPI
FastAPI Path / Query Parameters 정리 - 12
김잠봉
2022. 12. 22. 09:42
728x90
1. Path Parameters
- url 경로에 들어가는 변수
- book_name이 경로 매개변수
@app.delete("/{book_name}")
async def delete_book(book_name):
del BOOKS[book_name]
return f"Book {book_name} deleted."
data:image/s3,"s3://crabby-images/27df9/27df9fc5222110846638376f065c164b8fdb37f3" alt=""
data:image/s3,"s3://crabby-images/da997/da9973cbe84eb4024a39f529dded10c02db650d3" alt=""
2. Query Parameters
- url 구문 제일 뒤에 "/" 붙혀도 되고 안붙혀도 됨
- ?(매개변수 값)와 &(추가 값)로 구분
@app.delete("/assignment/")
async def delete_book_assignment(book_name: str):
del BOOKS[book_name]
return BOOKS
data:image/s3,"s3://crabby-images/b3225/b32254cf573d9890ba6e65dc06de6aa67596575b" alt=""
data:image/s3,"s3://crabby-images/e5eac/e5eacc6d26f55bd640ba4f1f10142eb26951623e" alt=""
3. Path / Query Parameter 종합
@app.get("/{apple}") # Path Parameter
async def test(apple):
return f"{apple} good"
@app.get("/apple") # Query Parameter
async def test(apple):
return f"{apple} good"
@app.get("/{fruit}") # Query Parameter
async def test(apple):
return f"{apple} good"
4. 선택적 쿼리 매개변수
- Default값이 None임으로 전체리스트 return or 선택 값만 return
@app.get("/")
async def read_all_books(skip_book: Optional[str] = None):
if skip_book:
new_books = BOOKS.copy()
del new_books[skip_book]
return new_books
return BOOKS
data:image/s3,"s3://crabby-images/40c00/40c0093269bc3cf9688ea3a148f5dff961bf38a0" alt=""
data:image/s3,"s3://crabby-images/e6ed1/e6ed15260378f50872281a3c0375911615cc92e5" alt=""
data:image/s3,"s3://crabby-images/33946/339465d5219ed6052332534763cc0fdfcd57acb2" alt=""
5. 필수 쿼리 매개변수
- url에도 반드시 매개변수값을 설정해줘야한다.
@app.get("/books/{book_name}")
async def read_book(book_name: str, book_id: str):
return f"{BOOKS[book_name+book_id]}"
data:image/s3,"s3://crabby-images/85bcd/85bcd84077e29bc9ec1bad77e8b5427df5592d36" alt=""
data:image/s3,"s3://crabby-images/30448/3044891a0a2cb791cf04b61972589a3ef0af3fec" alt=""
data:image/s3,"s3://crabby-images/d6ad7/d6ad73e75b665ecbe818ce1d95aaa8b3b489a5b9" alt=""
5. 에러사항 확인
728x90
SMALL