Microsoft MVP성태의 닷넷 이야기
오류 유형: 749. PyCharm - Error: Django is not importable in this environment [링크 복사], [링크+제목 복사]
조회: 8192
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

PyCharm - Error: Django is not importable in this environment

django-admin으로 프로젝트 생성 후,

c:\pycharm\work> django-admin startproject testapp

해당 디렉터리를 PyCharm에서 열어 (편집 화면 우측 상단의 "Indexing..."이 끝나기 전에) "F5" 키로 실행하면 다음과 같은 예외가 발생합니다.

(<class 'ImportError'>, ImportError("Couldn't import Django. Are you sure it's installed and available on your PYTHONPATH environment variable? Did you forget to activate a virtual environment?"), <traceback object at 0x000001F3EE2E3788>)


Indexing이 완료되고 나면 그 이후에는 "F5" 실행 시 다음과 같은 "Edit Configuration" 창이 뜨면서,

pycharm_django_prj_1.png

하단에 "Error: Django is not importable in this environment"라는 메시지가 나옵니다. 그리고 그 상단의 "Python Interpreter"도 PyCharm에 등록된 파이썬 실행 모듈 경로를 보여줍니다. 물론, 원인은 메시지에 나온 그대로입니다.

자, 그럼 해결을 해볼까요? 관리를 편하게 하기 위해, 우선 해당 프로젝트를 위한 virtualenv를 생성해 주고,

F:\pycharm_venv\pythonProject> virtualenv testapp

"Edit Configuration" 창에서 "Python Interpreter"를 저 경로에 생성된 "F:\pycharm_venv\pythonProject\testapp\Scripts\python.exe"로 설정해야 하는데, 아쉽게도 "Edit Configuration" 창의 "Python Interpreter"는 새로운 경로를 추가할 수 없습니다.

대신 Ctrl + Alt + S 키를 눌러 설정 창으로 간 후, "Project" 범주의 "Python Interpreter"에서 톱니바퀴 모양의 아이콘을 눌러 "Show All..."을 선택하면 다음 화면과 같이 새롭게 "F:\pycharm_venv\pythonProject\testapp\Scripts\python.exe" 경로를 추가/설정합니다. (관련 문서: Configure a Python interpreter)

pycharm_django_prj_2.png

이후 다시 F5 키를 눌러 뜨는 "Edit Configuration" 창을 보면 여전히 "Error: Django is not importable in this environment" 메시지가 나옵니다. 왜냐하면 우리가 생성한 virtualenv에는 Django를 위한 설정이 아무것도 없기 때문입니다. 실제로 다시 "Ctrl + Alt + S" 설정 창에 가보면 다음과 같이 우리가 선택한 환경의 Package가 "pip", "setuptools", "wheel" 3개만 포함된 것으로 확인할 수 있습니다.

따라서 여기에 "+" 버튼을 눌러,

pycharm_django_prj_3.png

Django 패키지를 추가합니다. 또는 명령행에서 F:\pycharm_venv\pythonProject\testapp\Scripts\ 경로로 이동해 (혹은, 가상 환경을 활성화한 후) 직접 "pip install Django"로 설치해도 됩니다.

이후, F5 키를 눌러 실행하면 아무런 문제 없이 Django 앱이 실행되는 것을 확인할 수 있습니다.




개발이 진행될수록 의존성이 늘어날 텐데요, 이후 다음의 명령으로 의존성 목록을 구할 수 있습니다.

$ pip freeze > requirements.txt

그리고, requirements.txt 파일의 내용에 따라 다른 환경에서 프로젝트를 재구성할 때 다음의 명령어로 의존성 패키지들을 복구할 수 있습니다. (닷넷과 비교하면, 'nuget restore'입니다. ^^)

$ pip install -r requirements.txt




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/10/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13500정성태12/24/20232176디버깅 기술: 194. Windbg - x64 가상 주소를 물리 주소로 변환
13498정성태12/23/20232812닷넷: 2186. 한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지
13497정성태12/22/20232293오류 유형: 885. Visual Studiio - error : Could not connect to the remote system. Please verify your connection settings, and that your machine is on the network and reachable.
13496정성태12/21/20232306Linux: 66. 리눅스 - 실행 중인 프로세스 내부의 환경변수 설정을 구하는 방법 (gdb)
13495정성태12/20/20232316Linux: 65. clang++로 공유 라이브러리의 -static 옵션 빌드가 가능할까요?
13494정성태12/20/20232499Linux: 64. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) - 두 번째 이야기
13493정성태12/19/20232541닷넷: 2185. C# - object를 QueryString으로 직렬화하는 방법
13492정성태12/19/20232261개발 환경 구성: 699. WSL에 nopCommerce 예제 구성
13491정성태12/19/20232231Linux: 63. 리눅스 - 다중 그룹 또는 사용자를 리소스에 권한 부여
13490정성태12/19/20232344개발 환경 구성: 698. Golang - GLIBC 의존을 없애는 정적 빌드 방법
13489정성태12/19/20232132개발 환경 구성: 697. GoLand에서 ldflags 지정 방법
13488정성태12/18/20232066오류 유형: 884. HTTP 500.0 - 명령행에서 실행한 ASP.NET Core 응용 프로그램을 실행하는 방법
13487정성태12/16/20232381개발 환경 구성: 696. C# - 리눅스용 AOT 빌드를 docker에서 수행 [1]
13486정성태12/15/20232194개발 환경 구성: 695. Nuget config 파일에 값 설정/삭제 방법
13485정성태12/15/20232088오류 유형: 883. dotnet build/restore - error : Root element is missing
13484정성태12/14/20232161개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
13483정성태12/14/20232295닷넷: 2184. C# - 하나의 resource 파일을 여러 프로그램에서 (AOT 시에도) 사용하는 방법파일 다운로드1
13482정성태12/13/20232812닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법 [2]파일 다운로드1
13481정성태12/13/20232265개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법파일 다운로드1
13480정성태12/12/20232597개발 환경 구성: 692. Windows WSL 2 + Chrome 웹 브라우저 설치
13479정성태12/11/20232282개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정
13477정성태12/8/20232465닷넷: 2182. C# - .NET 7부터 추가된 Int128, UInt128 [1]파일 다운로드1
13476정성태12/8/20232202닷넷: 2181. C# - .NET 8 JsonStringEnumConverter의 AOT를 위한 개선파일 다운로드1
13475정성태12/7/20232261닷넷: 2180. .NET 8 - 함수 포인터에 대한 Reflection 정보 조회파일 다운로드1
13474정성태12/6/20232133개발 환경 구성: 690. 닷넷 코어/5+ 버전의 ilasm/ildasm 실행 파일 구하는 방법 - 두 번째 이야기
13473정성태12/5/20232309닷넷: 2179. C# - 값 형식(Blittable)을 메모리 복사를 이용해 바이트 배열로 직렬화/역직렬화파일 다운로드1
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...