인프런 커뮤니티 질문&답변

이승렬님의 프로필 이미지
이승렬

작성한 질문수

파이썬 API 마스터! FastAPI

엔드포인트와 HTTP 메서드!

엔드포인트와 HTTP 메서드! / 질문

해결된 질문

작성

·

225

1

강의 상에 설명으로는 이해가 부족하여 질문 합니다.
1. 앞에 작성한 코드에 코드명이 따로 안나와 있어서 앞 선 코드가(import logging으로 시작하는 코드) main.py가 맞을까요?

  1. 실행 결과가 강의 창(16:14)만으로는 이해가 안되어서 main.py를 'uvicorn main:app' 으로 실행한 후에 client.py를 터미널 상에 실행하면 되는건가요?

ps. 강의자료를 github주소로 기재해주신다고 하셨는데 github주소를 찾을 수 없어서 추가로 문의 드립니다

답변 2

0

배코블린님의 프로필 이미지
배코블린
지식공유자

추가 질문이 있으시면 항상 알림을 확인하기 때문에! 빠르게 답변드릴 것이라는 점 약속드립니다 🙂

0

배코블린님의 프로필 이미지
배코블린
지식공유자

안녕하세요 강사 배코블린입니다!

 

먼저 강의를 수강해주셔서 감사하다는 말씀을 드리고, 피드백에 대해서도 정말 감사인사를 드립니다 :)

 

네 맞습니다!

 

다음의 코드를 main.py에 기입하신 후 uvicorn 명령어로 실행하시면 됩니다!

 

uvicorn의 명령어로 실행하면 main.py의 Fastapi로 구현한 api가 uvicorn 서버로 실행되게 됩니다.

 

그러면 저희는 서버를 오픈한 것이에요! 참고로 uvicorn main:app 명령어는 main 소스코드안의 app 인스턴스를 서버로 실행하는 명령어 입니다! (uvicorn에 대한 강의도 하나 추가해드리면 좋을 듯 하군요!)

 

이제 사용자 코드를 동작시키면 서버에 접속해 API를 사용할 수 있는데, 그 코드가 client.py 코드 입니다!

 

강의 화면 상의 좌측의 출력은 서버의, 우측의 출력은 클라이언트의 출력입니다.

 

현재 이런 식으로 코드가 있지만 강의 내용 자체를 주석으로 추가하는 작업을 진행 중 입니다!

 

모르는 부분이 있을 때 강의를 다시 들으시는 것도 좋지만 바로 설명이 있으면 더 좋을 것 같아서요!

 

이 작업이 완료되면 바로 링크와 강의자료 전자책을 제공해드리겠습니다 🙂

 

감사합니다!

추가 질문이 있으시면 언제든 항상 편하게 남겨주세요!

import logging
from fastapi import FastAPI, Form

logging.basicConfig(level =logging.INFO)
logger = logging.getLogger(__name__)

app = FastAPI()

items = {"1": {"name" : "pen"}, "2":{"name":"pencil"}}

@app.get("/items")
async def read_items():
    logger.info("Fetching all items")
    return items


@app.post("/items/{item_id}")
async def create_item(item_id : str, name: str = Form(...)):
    items[item_id] = {"name": name}
    logger.info(f"item created: {item_id} - {name}")
    return items[item_id]


@app.put("/items/{item_id}")
async def update_item(item_id: str, name :str = Form(...)):
    items[item_id] = {"name" : name}
    logger.info(f"item updated: {item_id} - {name}")
    return items[item_id]

@app.delete("/items/{item_id}")
async def delete_item(item_id: str):
    if item_id in items:
        del items[item_id]
        logger.info(f"item deleted: {item_id}")
        return {"message:" "Item deleted"}
    else:
        logger.info(f"item not found: {item_id}")
        return {"message": "item not found"}

@app.patch("/items/{item_id}")
async def patch_item(item_id: str, name: str =Form(...)):
    if item_id in items:
        items[item_id]["name"] = name
        logger.info(f"Item patched: {item_id} - {name}")
        return items[item_id]
    else:
        logger.info(f"Item not found {item_id}")
        return {"message": "Item not found"}
    
이승렬님의 프로필 이미지
이승렬

작성한 질문수

질문하기