1. Python에서 import 문과 상대 경로 import 개요
Python으로 프로그램을 작성할 때, import 문을 사용하여 모듈을 효율적으로 재사용합니다. 이 import 문에서 상대 경로 import는 모듈 간의 유연한 의존성이 있을 때 특히 유용합니다. 이 문서에서는 Python의 import 문에서 상대 경로를 사용하는 방법과 그 장점에 대해 설명합니다.
상대 경로 import란?
상대 경로 import는 현재 모듈의 위치를 기준으로 다른 모듈을 가져오는 방법입니다. 여러 모듈을 포함하는 대규모 프로젝트나 패키지 개발에 특히 유용합니다. 상대 경로 import를 사용하면 모듈 간 의존성을 명확히 할 수 있어 프로젝트 유지보수가 쉬워집니다.
예를 들어, 다음과 같은 디렉터리 구조가 있다고 가정해 보겠습니다.
project/
├── main.py
├── package/
│ ├── module_a.py
│ └── sub_package/
│ └── module_b.py
module_b.py에서 module_a.py를 상대 경로로 import하려면 다음과 같이 작성합니다.
from ..module_a import some_function
이처럼 상대 경로를 사용하면 디렉터리 계층 구조에 따라 유연하게 모듈을 가져올 수 있습니다.

2. 상대 경로와 절대 경로의 차이
Python의 import 문에는 두 가지 유형이 있습니다: 상대 경로와 절대 경로. 이 둘의 차이는 대상 모듈을 지정하는 방식에 있습니다.
절대 경로 Import
절대 경로 import는 프로젝트의 루트 디렉터리부터 시작하여 모듈을 지정합니다.
예를 들어, 다음과 같은 구조를 가진 프로젝트에서 module_a.py를 main.py에 절대 경로로 import하려면 다음과 같이 작성합니다.
from package.module_a import some_function
이 방법은 프로젝트 전체 구조가 명확하고 모듈 위치가 일관될 때 유용합니다.
상대 경로 Import
반면에 상대 경로 import는 현재 모듈의 위치를 기준으로 모듈을 가져옵니다. 프로젝트 구조가 변경될 때 상대 경로 import는 비교적 유연하게 동작합니다. 이를 통해 모듈 간 의존성을 유지하면서 코드 재사용성을 높일 수 있습니다.
예를 들어, 현재 모듈보다 한 단계 위 디렉터리에 있는 모듈을 import하는 코드는 다음과 같습니다.
from ..module_a import some_function
어떤 옵션을 선택할지는 프로젝트의 규모와 복잡도에 따라 다릅니다. 일반적으로 모듈 위치가 고정된 경우에는 절대 경로 import가 적합하고, 변경이 자주 발생하는 경우에는 상대 경로 import가 더 적합합니다.
3. 상대 경로를 이용한 Import
같은 디렉터리에서 모듈 Import
같은 디렉터리에 있는 모듈을 import할 때는 복잡한 지정이 필요 없으며, 모듈 이름만 직접 사용하면 됩니다. 예를 들어 module_a.py와 module_b.py가 같은 디렉터리에 있다면 다음과 같이 import할 수 있습니다.
import module_a
특정 함수나 클래스를 import하려면 다음과 같이 작성합니다.
from module_a import some_function
상위 디렉터리에서 Import
상위 디렉터리에 있는 모듈을 import할 때는 ..을 사용해 한 단계 위로 이동한 뒤 모듈을 지정합니다. 예를 들어 한 단계 위에서 import하려면 다음과 같이 작성합니다.
from ..module_a import some_function
하위 디렉터리에서 Import
하위 디렉터리의 모듈을 import할 때는 디렉터리 이름과 모듈 이름을 점(.)으로 구분하여 지정합니다. 예를 들어 하위 디렉터리에서 모듈을 import하려면 다음과 같이 작성합니다.
from sub_package.module_b import some_function
상대 경로를 사용하면 프로젝트 디렉터리 구조가 변경되더라도 코드가 유연하게 유지된다는 큰 장점이 있습니다.
4. 패키지 내부 모듈 Import
Python은 모듈을 조직하기 위한 “패키지” 개념을 제공합니다. 패키지는 특히 대규모 프로젝트에서 여러 모듈을 그룹화하는 데 유용합니다. 패키지 내부에서도 상대 경로를 사용해 모듈을 import할 수 있습니다.
패키지 구조와 __init__.py 파일
패키지를 만들 때는 디렉터리에 __init__.py 파일을 추가해야 합니다. 이 파일은 파이썬에게 해당 디렉터리를 패키지로 인식하도록 알려줍니다. 아래에서는 다음과 같은 구조를 가진 프로젝트를 예시로 설명합니다.
project/
├── main.py
├── package/
│ ├── __init__.py
│ ├── module_a.py
│ └── sub_package/
│ ├── __init__.py
│ └── module_b.py
패키지 내 모듈의 상대 경로 임포트
예를 들어 module_b.py에서 module_a.py를 상대 경로로 임포트하려면 다음과 같이 작성합니다.
from ..module_a import some_function
이 ..은 현재 디렉터리에서 한 단계 위로 이동한다는 의미입니다. 이렇게 하면 패키지 내 모듈 간에 함수와 클래스를 공유할 수 있습니다.
또한 같은 패키지 내에서 모듈을 상대 경로로 임포트할 때는 점(.) 하나만으로 쉽게 지정할 수 있습니다.
from .module_a import some_function
이렇게 하면 프로젝트 내 모듈들이 간결하게 상호 작용할 수 있으며, 디렉터리 구조가 바뀌어도 큰 코드 수정이 필요하지 않습니다.
5. 흔히 발생하는 오류와 해결 방법
파이썬 상대 경로 임포트에서는 여러 가지 일반적인 오류가 발생할 수 있습니다. 이 섹션에서는 이러한 오류와 해결 방법을 설명합니다.
ImportError: attempted relative import with no known parent package
이 오류는 특히 스크립트를 직접 실행할 때 상대 경로로 모듈을 임포트하려고 하면 흔히 발생합니다. 예를 들어 다음과 같은 코드가 문제를 일으킬 수 있습니다.
from ..module_a import some_function
이 오류는 파이썬이 스크립트의 상위 패키지를 인식하지 못하기 때문에 발생합니다. 파이썬에서는 모듈이 패키지의 일부로 명확히 인식되어야 합니다. 스크립트를 직접 실행할 경우 상대 경로를 사용하면 오류가 발생하기 쉽습니다.
해결 방법
이 문제를 피하려면 sys.path를 사용해 모듈 검색 경로를 명시적으로 설정합니다. 예를 들어 sys.path.append()를 이용해 상위 디렉터리를 검색 경로에 추가할 수 있습니다.
import sys
sys.path.append('..')
from module_a import some_function
이렇게 하면 파이썬이 모듈을 올바르게 찾을 수 있습니다.
ModuleNotFoundError
또 다른 흔한 오류는 ModuleNotFoundError입니다. 지정한 모듈을 찾을 수 없을 때 발생합니다. 상대 경로로 모듈을 임포트하려 할 때 모듈 위치가 잘못되었거나 sys.path가 올바르게 설정되지 않았을 가능성이 있습니다.
해결 방법
이 문제를 해결하려면 임포트 구문을 검토하고 모듈이 실제로 존재하는지 확인합니다. 또한 sys.path.append()를 사용해 파이썬이 모듈을 찾을 수 있는 디렉터리를 명시적으로 지정하면 오류를 방지할 수 있습니다.

6. 실용적인 예제와 적용
여기서는 상대 경로 임포트를 활용한 구체적인 코드 예제를 제시합니다. 이를 통해 실제 프로젝트에서 상대 경로를 어떻게 활용할 수 있는지 보여줍니다.
예제: 상위 디렉터리에서 임포트하기
다음과 같은 프로젝트 구조를 가정합니다.
project/
├── main.py
├── package/
│ ├── module_a.py
│ └── sub_package/
│ └── module_b.py
module_b.py에서 module_a.py의 함수 some_function을 임포트하는 코드는 아래와 같습니다.
# module_b.py
from ..module_a import some_function
def use_function():
some_function()
이 코드에서는 ..을 사용해 한 디렉터리 위로 올라가고, module_a에서 함수를 임포트합니다. 여러 디렉터리에 걸쳐 있는 모듈 간에 함수나 클래스를 공유할 때 유용한 방법입니다.
예제: sys.path를 이용한 모듈 임포트
다음은 sys.path.append()를 사용해 상위 디렉터리 모듈을 임포트하는 예제입니다.
# module_b.py
import sys
sys.path.append('..')
from module_a import some_function
def use_function():
some_function()
이 방법에서는 sys.path에 상위 디렉터리를 추가함으로써 파이썬이 module_a를 올바르게 찾을 수 있게 합니다. 스크립트를 직접 실행할 때 특히 효과적입니다.
7. 결론
이 기사에서는 Python의 import 문에서 상대 경로 가져오기(relative‑path imports)에 대해 심도 있게 살펴보았습니다. 상대 경로 가져오기는 대규모 프로젝트와 패키지 개발에 특히 유용한데, 모듈 간 의존성을 유연하게 관리할 수 있게 해주기 때문입니다. 그러나 오류가 발생하기 쉬우므로 적절한 설정과 sys.path 사용이 중요합니다.
상대 경로 가져오기의 장점을 이해하고 실제 프로젝트에 적용하면 보다 효율적인 코드 관리가 가능합니다.




