runpy — 파이썬 모듈 찾기와 실행¶
소스 코드: Lib/runpy.py
The runpy module is used to locate and run Python modules without
importing them first. Its main use is to implement the -m command
line switch that allows scripts to be located using the Python module
namespace rather than the filesystem.
이것은 샌드박스 모듈이 아닙니다 - 모든 코드가 현재 프로세스에서 실행되고, 모든 부작용(가령 다른 모듈의 캐시된 임포트)은 함수가 반환된 후에도 그대로 유지됩니다.
Furthermore, any functions and classes defined by the executed code are not
guaranteed to work correctly after a runpy function has returned.
If that limitation is not acceptable for a given use case, importlib
is likely to be a more suitable choice than this module.
The runpy module provides two functions:
- runpy.run_module(mod_name, init_globals=None, run_name=None, alter_sys=False)¶
지정된 모듈의 코드를 실행하고 결과 모듈의 전역 딕셔너리를 반환합니다. 모듈의 코드는 먼저 표준 임포트 메커니즘(자세한 내용은 PEP 302를 참조하십시오)을 사용하여 찾은 다음 새로운 모듈 이름 공간에서 실행됩니다.
mod_name 인자는 절대 모듈 이름이어야 합니다. 모듈 이름이 일반 모듈이 아닌 패키지를 참조하면, 해당 패키지를 임포트하고 그 패키지 내의
__main__서브 모듈을 실행하고 결과 모듈 전역 딕셔너리를 반환합니다.선택적 딕셔너리 인자 init_globals는 코드가 실행되기 전에 모듈의 전역 딕셔너리를 미리 채우기 위해 사용될 수 있습니다. init_globals는 수정되지 않습니다. 아래의 특수 전역 변수가 init_globals에 정의되어 있으면, 해당 정의가
run_module()에 의해 대체됩니다.특수 전역 변수
__name__,__spec__,__file__,__cached__,__loader__및__package__는 모듈 코드가 실행되기 전에 전역 딕셔너리에 설정됩니다. (이 변수는 최소한의 변수 집합임에 유의하십시오 - 인터프리터 구현 세부 사항에 따라 다른 변수가 묵시적으로 설정될 수 있습니다.)__name__은 (이 선택적 인자가None이 아니면) run_name으로, 명명된 모듈이 패키지면mod_name + '.__main__'으로, 그렇지 않으면 mod_name 인자로 설정됩니다.__spec__은 실제로 임포트 된 모듈에 맞게 설정됩니다 (즉,__spec__.name은 항상 mod_name이나mod_name + '.__main__'이 됩니다, 절대 run_name은 아닙니다).__file__,__cached__,__loader__및__package__는 모듈 스펙에 따라 표준적으로 설정됩니다.인자 alter_sys가 제공되고
True로 평가되면,sys.argv[0]은__file__값으로 갱신되고sys.modules[__name__]은 실행 중인 모듈에 대한 임시 모듈 객체로 갱신됩니다.sys.argv[0]과sys.modules[__name__]은 함수가 반환되기 전에 원래 값으로 복원됩니다.이
sys조작은 스레드-안전하지 않습니다. 다른 스레드가 부분적으로 초기화된 모듈과 변경된 인자 목록을 볼 수 있습니다. 스레드를 사용하는 코드에서 이 함수를 호출할 때sys모듈을 단독으로 두는 것이 좋습니다.더 보기
명령 줄에서 동등한 기능을 제공하는
-m옵션.버전 3.1에서 변경:
__main__서브 모듈을 찾아 패키지를 실행할 수 있는 기능 추가.버전 3.2에서 변경:
__cached__전역 변수 추가 (PEP 3147을 참조하십시오).버전 3.4에서 변경: PEP 451이 추가한 모듈 스펙 기능을 활용하도록 갱신되었습니다. 이것은 실제 모듈 이름을 항상
__spec__.name으로 액세스할 수 있으면서,__cached__가 이 방법으로 실행되는 모듈에 대해 올바르게 설정되도록 합니다.버전 3.12에서 변경:
__cached__,__loader__및__package__의 설정은 폐지되었습니다. 대안은ModuleSpec을 참조하세요.
- runpy.run_path(path_name, init_globals=None, run_name=None)¶
명명된 파일 시스템 위치에 있는 코드를 실행하고 결과 모듈의 전역 딕셔너리를 반환합니다. CPython 명령 줄에 제공된 스크립트 이름과 마찬가지로, file_path는 파이썬 소스 파일, 컴파일된 바이트 코드 파일 또는
__main__모듈이 포함된 유효한sys.path항목(예를 들어, 최상위 수준__main__.py파일을 포함하는 zip 파일)을 가리킬 수 있습니다.간단한 스크립트의 경우, 지정된 코드는 단순히 새로운 모듈 이름 공간에서 실행됩니다. 유효한
sys.path항목(보통 zip 파일이나 디렉터리)의 경우, 항목이 먼저sys.path의 시작 부분에 추가됩니다. 그런 다음 함수는 갱신된 경로를 사용하여__main__모듈을 찾아 실행합니다. 지정된 위치에 해당 모듈이 없을 때sys.path의 다른 위치에 있는 기존__main__항목을 호출하는 것을 막는 특별한 보호 장치가 없다는 점에 유의하십시오.선택적 딕셔너리 인자 init_globals는 코드가 실행되기 전에 모듈의 전역 딕셔너리를 미리 채우기 위해 사용될 수 있습니다. init_globals는 수정되지 않습니다. 아래의 특수 전역 변수가 init_globals에 정의되어 있으면, 해당 정의가
run_path()에 의해 대체됩니다.특수 전역 변수
__name__,__spec__,__file__,__cached__,__loader__및__package__는 모듈 코드가 실행되기 전에 전역 딕셔너리에 설정됩니다. (이 변수는 최소한의 변수 집합임에 유의하십시오 - 인터프리터 구현 세부 사항에 따라 다른 변수가 묵시적으로 설정될 수 있습니다.)__name__은 (이 선택적 인자가None이 아니면) run_name으로, 그렇지 않으면'<run_path>'로 설정됩니다.file_path가 스크립트 파일(소스나 사전 컴파일된 바이트 코드)을 직접 참조하면,
__file__은 file_path로 설정되고__spec__,__cached__,__loader__및__package__는 모두None으로 설정됩니다.file_path가 유효한
sys.path항목에 대한 참조면,__spec__은 임포트 된__main__모듈에 대해 적절하게 설정됩니다 (즉,__spec__.name은 항상__main__이 됩니다).__file__,__cached__,__loader__및__package__는 모듈 스펙에 따라 표준적으로 설정됩니다.sys모듈에도 여러 가지 변경이 적용됩니다. 첫째,sys.path는 위에서 설명한 것처럼 변경될 수 있습니다.sys.argv[0]은 file_path 값으로 갱신되고sys.modules[__name__]은 실행 중인 모듈에 대한 임시 모듈 객체로 갱신됩니다. 함수가 반환되기 전에sys의 항목에 대한 모든 수정 내용이 되돌려집니다.run_module()과 달리,sys에 대한 변경은 이 함수에서는 선택 사항이 아닌데, 이 조정이sys.path항목의 실행을 허용하는 데 필수적이기 때문입니다. 스레드-안전 제약 사항이 계속 적용되므로, 스레드를 사용하는 코드에서 이 함수를 사용하려면 임포트 잠금을 사용하여 직렬화하거나 별도의 프로세스에 위임해야 합니다.더 보기
명령 줄에서의 동등한 기능에 대한 인터페이스 옵션 (
python path/to/script).Added in version 3.2.
버전 3.4에서 변경: PEP 451이 추가한 모듈 스펙 기능을 활용하도록 갱신되었습니다. 이것은
__main__이 직접 실행되는 대신 유효한sys.path항목에서 임포트 될 때__cached__가 올바르게 설정되도록 합니다.버전 3.12에서 변경:
__cached__,__loader__및__package__의 설정은 폐지되었습니다.