> 백엔드 개발 > 파이썬 튜토리얼 > Python의 깔끔한 코드와 모범 사례

Python의 깔끔한 코드와 모범 사례

Patricia Arquette
풀어 주다: 2025-01-06 10:17:41
원래의
693명이 탐색했습니다.

Clean Code and Good Practices in Python

깔끔하고 유지 관리가 가능한 Python 코드를 작성하는 것은 모든 개발자에게 필수적인 기술입니다. 깔끔한 코드는 작업을 더 읽기 쉽고 효율적으로 만들 뿐만 아니라 다른 사람들이 프로젝트를 쉽게 이해하고 유지 관리할 수 있도록 해줍니다. 이 기사에서는 깔끔한 Python 코드를 작성하기 위한 주요 원칙과 모범 사례를 살펴보겠습니다.


1. PEP 8 스타일 지침을 따르세요

PEP 8은 Python의 공식 스타일 가이드이며 읽기 쉽고 일관된 코드를 작성하기 위한 규칙을 제공합니다. pylint 및 flake8과 같은 도구는 코드가 이러한 표준을 준수하는지 확인하는 데 도움이 됩니다.

주요 PEP 8 규칙:

  • 들여쓰기는 공백 4개를 사용하세요.
  • 줄을 79자로 제한하세요.
  • 변수와 함수에는 의미 있는 이름을 사용하세요.

예:

# Good
def calculate_total_price(price, tax_rate):
    return price + (price * tax_rate)
로그인 후 복사
로그인 후 복사

2. 설명적이고 의미 있는 이름을 작성하세요

이름은 변수, 함수, 클래스의 목적을 명확하게 설명해야 합니다. 단일 문자나 모호한 용어를 사용하지 마세요.

❌ 나쁨:

def func(x, y):
    return x + y
로그인 후 복사
로그인 후 복사

✅ 좋음:

def add_numbers(number1, number2):
    return number1 + number2
로그인 후 복사
로그인 후 복사

지침:

  • 변수 및 함수 이름에는 snake_case를 사용하세요.
  • 클래스 이름에는 PascalCase를 사용하세요.

3. 함수와 클래스를 작게 유지

함수는 한 가지 일을 잘 수행해야 합니다. 마찬가지로 클래스는 단일 책임 원칙(SRP)

을 준수해야 합니다.

❌ 나쁨:

def process_user_data(user):
    # Validating user
    if not user.get('name') or not user.get('email'):
        return "Invalid user"

    # Sending email
    print(f"Sending email to {user['email']}")
    return "Success"
로그인 후 복사
로그인 후 복사

✅ 좋음:

def validate_user(user):
    return bool(user.get('name') and user.get('email'))

def send_email(email):
    print(f"Sending email to {email}")

def process_user_data(user):
    if validate_user(user):
        send_email(user['email'])
        return "Success"
    return "Invalid user"
로그인 후 복사
로그인 후 복사

4. 마법의 숫자와 문자열에 상수 사용

코드에 직접 하드코딩된 값을 사용하지 마세요. 더 나은 가독성과 유지 관리성을 위해 상수로 정의하세요.

❌ 나쁨:

if order_total > 100:
    discount = 10
로그인 후 복사
로그인 후 복사

✅ 좋음:

MINIMUM_DISCOUNT_THRESHOLD = 100
DISCOUNT_PERCENTAGE = 10

if order_total > MINIMUM_DISCOUNT_THRESHOLD:
    discount = DISCOUNT_PERCENTAGE
로그인 후 복사
로그인 후 복사

5. 간단한 변환을 위해 List Comprehension 사용

목록 이해는 코드를 더욱 간결하고 Python답게 만듭니다. 그러나 지나치게 복잡하게 만드는 것은 피하세요.

❌ 나쁨:

squared_numbers = []
for number in range(10):
    squared_numbers.append(number ** 2)
로그인 후 복사

✅ 좋음:

squared_numbers = [number ** 2 for number in range(10)]
로그인 후 복사

6. 변경 가능한 기본 인수를 피하세요

목록이나 사전과 같은 변경 가능한 개체를 기본 인수로 사용하면 예기치 않은 동작이 발생할 수 있습니다.

❌ 나쁨:

def append_to_list(value, items=[]):
    items.append(value)
    return items
로그인 후 복사

✅ 좋음:

def append_to_list(value, items=None):
    if items is None:
        items = []
    items.append(value)
    return items
로그인 후 복사

7. 예외를 적절하게 처리

Python에서는 오류 처리에 예외 사용을 권장합니다. 오류를 처리하고 의미 있는 메시지를 제공하려면 try...out 블록을 사용하세요.

예:

# Good
def calculate_total_price(price, tax_rate):
    return price + (price * tax_rate)
로그인 후 복사
로그인 후 복사

8. DRY(반복하지 마세요) 코드 작성

코드에서 논리가 중복되지 않도록 하세요. 공통 기능을 재사용 가능한 함수 또는 클래스로 추출합니다.

❌ 나쁨:

def func(x, y):
    return x + y
로그인 후 복사
로그인 후 복사

✅ 좋음:

def add_numbers(number1, number2):
    return number1 + number2
로그인 후 복사
로그인 후 복사

9. Docstring 및 주석 사용

복잡한 논리 이면의 "이유"를 설명하기 위해 의미 있는 독스트링과 주석으로 코드를 문서화하세요.

예:

def process_user_data(user):
    # Validating user
    if not user.get('name') or not user.get('email'):
        return "Invalid user"

    # Sending email
    print(f"Sending email to {user['email']}")
    return "Success"
로그인 후 복사
로그인 후 복사

10. 유형 힌트 사용

입력 힌트를 사용하면 코드를 더 쉽게 읽을 수 있으며 mypy와 같은 도구로 오류를 조기에 포착할 수 있습니다.

예:

def validate_user(user):
    return bool(user.get('name') and user.get('email'))

def send_email(email):
    print(f"Sending email to {email}")

def process_user_data(user):
    if validate_user(user):
        send_email(user['email'])
        return "Success"
    return "Invalid user"
로그인 후 복사
로그인 후 복사

11. 코드 테스트

코드가 예상대로 작동하는지 확인하기 위해 항상 테스트를 작성하세요. Unittest 또는 pytest와 같은 프레임워크를 사용하세요.

예:

if order_total > 100:
    discount = 10
로그인 후 복사
로그인 후 복사

12. 가상 환경 사용

가상 환경을 사용하여 충돌을 방지하려면 프로젝트 종속성을 격리하세요.

명령:

MINIMUM_DISCOUNT_THRESHOLD = 100
DISCOUNT_PERCENTAGE = 10

if order_total > MINIMUM_DISCOUNT_THRESHOLD:
    discount = DISCOUNT_PERCENTAGE
로그인 후 복사
로그인 후 복사

마지막 한마디

클린 코드는 단순한 규칙 집합이 아니라 사고방식입니다. 이러한 모범 사례를 채택하면 읽기 쉽고 유지 관리가 가능하며 전문적인 Python 코드를 작성할 수 있습니다. 클린 코드는 본인뿐만 아니라 코드를 사용하는 모든 사람에게 도움이 된다는 점을 기억하세요.

Python에서 가장 좋아하는 클린 코드 연습은 무엇인가요? 아래 댓글로 여러분의 팁을 공유해주세요!

위 내용은 Python의 깔끔한 코드와 모범 사례의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿