SW개발/Python

    [Python]파이썬 정렬 알고리즘, Timsort

    파이썬은 sort(), sorted() 메서드를 통해 정말 간편하게 정렬된 값을 얻을 수 있습니다. 사용하는 방법도 매우 쉽기에 내부 동작 원리에 대해서는 깊게 생각해본 적이 없었습니다. 이번 포스팅에서는 파이썬이 어떤 정렬 알고리즘을 사용하는지 알아보도록 하겠습니다. Timsort 파이썬은 Tim sort라는 정렬 알고리즘 표준으로 채택되어 사용 중입니다. Timsort는 삽입정렬과 병합정렬을 합친 알고리즘입니다. 2001년도에 고안되었으며, 창시자인 Tim Peters의 이름을 따왔습니다. 또한, 이 알고리즘은 파이썬 뿐만 아니라 Java SE7, Android, 구글 크롬 엔진등 다양한 곳에서 채택되어 사용중입니다. Timsort 특징 현실 세계의 데이터들은 완전 무작위가 아니라 어느정도는 정렬이..

    [Python]네임스페이스란(Namespace) ?

    지난번 Zen of Python에 잠깐 언급된 파이썬의 네임스페이스에 대해 알아보는 포스팅을 써보려고 합니다. 지난 포스팅 -> Zen of Python https://leffept.tistory.com/396 [Python]The Zen of Python - 파이써닉한 코드 파이썬에서의 디자인 원칙을 잘 나타내는 The Zen of Python이라는 것이 존재한다. 여기에 존재하는 원칙들을 바탕으로 자신이 작성한 코드가 파이써닉한 코드인지 아닌지에 대해서도 생각해볼 수 leffept.tistory.com 네임스페이스란 ? 네임스페이스란 특정한 객체를 이름에 따라 구분할 수 있는 범위를 말합니다. 파이썬 내부의 모든 것들은 전부 객체로 구성되어 있고, 이들은 특정 이름들과의 매핑 관계를 가지고 있습니다...

    [Python]Function Parameter, Argument 에 대하여

    파이썬은 매우 자유도가 높은 언어이다. 따라서 함수를 사용하면서 인자값에 대해 큰 신경을 쓰지 않아도 에러 없이 편하게 프로그래밍을 할 수 있다. 하지만 그러다가 non-default argument follows default argument 라는 에러를 마주하게 되었고, 이번 기회에 파이썬 함수의 Paramter, Argument의 처리에 관해서 자세히 공부해보기 위해 포스팅을 작성하게 되었다. https://docs.python.org/ko/3.10/glossary.html 의 parameter, argument 참조. 용어집 — Python 3.10.4 문서 같은 형의 두 인자를 수반하는 연산이 일어나는 동안, 한 형의 인스턴스를 다른 형으로 묵시적으로 변환하는 것. 예를 들어, int(3.15)..

    [Python]The Zen of Python - 파이써닉한 코드

    파이썬에서의 디자인 원칙을 잘 나타내는 The Zen of Python이라는 것이 존재한다. 여기에 존재하는 원칙들을 바탕으로 자신이 작성한 코드가 파이써닉한 코드인지 아닌지에 대해서도 생각해볼 수 있을 것이다. https://www.python.org/dev/peps/pep-0020/ PEP 20 -- The Zen of Python The official home of the Python Programming Language www.python.org 파이썬 shell에서 import this를 입력하면 The Zen of Python 이스터에그를 확인할 수 있다. >>> import this Beautiful is better than ugly. 아름다운 것이 추한 것보다 낫다. Explicit i..

    [Python]TODO 주석 활용법 (feat. 주석 키워드)

    이번 포스팅에서는 TODO 주석을 활용하는 방법에 대해 알아보겠습니다. 1. TODO: # TODO: 해야할 작업 class Leffe(): pass TODO라는 키워드를 활용하여 해야할 작업이라는 표시를 정할 수 있습니다. 이와 비슷하게 프로그래머들 사이에서 널리 사용되는 주석의 키워드를 몇가지 더 알려드리겠습니다. 2. FIXME: # FIXME: 오작동을 일으킨다고 알려진 코드 class Leffe(): pass 오작동을 일으킨다고 알려진 코드에 적용할 수 있습니다. 3. HACK: # HACK: 아름답지 않은 해결책 class Leffe(): pass 해결책이 깔끔하지 않은 경우에 적용할 수 있습니다. 4. XXX: # XXX: 이곳에 큰 문제가 있다 class Leffe(): pass 큰 문제가..

    [Python]테스트코드 커버리지 측정 - coverage

    파이썬에서 작성한 테스트 코드의 커버리지를 측정하는 도구가 있다. https://github.com/nedbat/coveragepy GitHub - nedbat/coveragepy: Code coverage measurement for Python Code coverage measurement for Python. Contribute to nedbat/coveragepy development by creating an account on GitHub. github.com Coverage 설치 pip install coverage 먼저 측정을 위해 coverage라는 도구를 설치한다. .coveragerc 설정파일 추가 [run] include = /커버리지를 측정할 디렉토리명/* omit = *migra..

    [Python]예외처리 - try, except, else, finally (raise) 사용하기

    if, else 문으로만 모든 에러를 처리한다면 indent가 늘어남에 따라 가독성이 떨어지는 코드가 되기 마련입니다. 따라서, 예외처리 구문을 사용하여 코드를 깔끔하게 작성하도록 하여야 합니다. 이번 포스팅에서는 Python의 예외처리 방법에 대해서 간단하게 알아보겠습니다. Python의 예외처리의 기본 흐름은 try -> except -> else -> finally 순으로 진행됩니다. 모든 단계를 사용할 필요는 없고 필요에 따라 적절히 골라서 사용하면 됩니다. 하나씩 설명해보겠습니다. try & except try: # 에외처리할 코드 print(10/0) except ZeroDivisionError: # 발생하는 에러에 대한 처리 print("zero division error") 가장 기본적으로..

    [Python]isinstance() 란?

    isinstance(object, classinfo) 란? isinstance()는 주어진 인스턴스가 특정 클래스/데이터 타입인지 검사를 해주는 함수이다. 인스턴스가 특정 클래스/데이터 타입과 일치할 경우 True, 아닐 경우 False를 반환한다. print(isinstance(1, int)) # True, int 인지 검사 print(isinstance(1.123, float)) # True, float 인지 검사 print(isinstance({'a': 1}, dict) # True, dict 인지 검사 class Example: pass example = Example() print(isinstance(example, Example)) # True, Example 클래스 인지 검사

    [Python]hasattr(), getattr(), setattr() 함수란?

    파이썬에는 변수가 있는지 확인하는 함수로 3가지가 존재한다. 하나씩 차례대로 알아보자. hasattr(object, name) object에 name 속성 존재하는지 여부를 확인한다. class cls: a = 1 def b(self): pass # cls에 b가 존재할 경우 True 반환 print(hasattr(cls, 'b')) True getattr(object, name[, default]) object에 존재하는 name 속성의 값을 가져온다. class cls: a = 1 def b(self): pass # cls에서 a의 값을 가져오기 print(getattr(cls, 'a')) 1 setattr(object, name, value) object에 존재하는 name 속성의 값을 설정한다. ..

    [Python]property로 getter, setter 구현하기

    Python에서 getter, setter 구현하는 방법 Python 에서 getter와 setter 함수를 구현하는 방법은 2가지가 존재한다. property() 함수를 이용하는 방법 @property 속성을 이용하는 방법 하나씩 차례대로 알아보자. property() 함수 이용 class Person: def __init__(self): self._age = 0 def get_age(self): # getter return self._age def set_age(self, value): # setter self._age = value age = property(get_age, set_age) leffe = Person() leffe.age = 20 # 내부적으로 setter 호출 print(leffe..