Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 306. Visual Studio Code에서 Python 개발 환경 구성 [링크 복사], [링크+제목 복사]
조회: 42111
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio Code에서 Python 개발 환경 구성

당연히, Visual Studio Code를 다운로드해야겠지요! ^^

Download Visual Studio Code
; https://code.visualstudio.com/download

그다음, 아무 파이썬 파일이나 열어주면 Visual Studio Code가 알아서 다음과 같이 "Python" 확장을 설치할 거냐고 물어봐 줍니다.

vscode_python_1.png

It is recommended to install the 'Python' extension.

"Show recommendations" 버튼을 누르면 관련 '확장 도구' 목록들이 뜨고,

vscode_python_2.png

그중에서 (Don Jayamanne의) "Python"을 선택(물론, 취향에 따라 다른 Python 확장을 선택해도 됩니다.)하고 "Install" 버튼을 누르면 설치가 완료됩니다. 그 후 "Install" 버튼이 "Reload"로 바뀌는 데, 이를 눌러주면 Visual Studio Code가 다시 실행되면서 해당 확장을 함께 로드해 사용할 준비가 됩니다.




당연히, 편집 중인 파이썬 코드를 실행해봐야겠지요? ^^ 그전에 Visual Studio 개발 환경의 전통적인 "F5 (Start Debugging)"을 해보겠습니다. 파이썬 소스 코드가 열린 상태에서 "F5" 키를 누르면 최초 한 번은 해당 소스 코드가 어떤 환경에서 실행되어야 하는지를 묻는 창이 뜹니다.

vscode_python_3.png

위처럼, "Python"을 선택하면 현재 파이썬 소스 코드 파일의 경로 하위에 ".vscode" 폴더 및 그 내부에 "launch.json" 파일이 생성되고 동시에 Visual Studio Code 내의 편집 파일로 로드가 됩니다.

"launch.json"은 그냥 대충 훑어보시고, 다시 파이썬 소스 코드로 가서 "F5" 키를 누릅니다.

이 단계에서, 파이썬 확장 도구는 해당 컴퓨터에 설치된 "python.exe"를 이용하게 됩니다. 당연하겠지만, 해당 PC에 한 번도 python을 설치하지 않았다면 "F5" 키 실행은 되지 않고 다음과 같은 오류 메시지가 뜹니다.

vscode_python_4.png

Failed to launch the Python Process, please validate the path 'python'

Error: spawn python ENOENT

만약 설치한 적이 없다면 해주고, (여기서는 3.5.2 버전을 다운로드한 것으로 가정하겠습니다.)

Python Releases for Windows
; https://www.python.org/downloads/windows/

Windows x86-64 executable installer (설치 방법)
; https://www.python.org/ftp/python/3.5.2/python-3.5.2-amd64.exe

설치했는데도 동일한 오류가 발생한다면 시스템 환경 변수의 "PATH"에 python 설치 경로가 있는지 확인하고 없으면 등록해야 합니다. (이미 실행된 Visual Studio Code는 변경된 PATH 환경 변수를 인식하지 않으므로 새로 실행해야 합니다.)

여기까지 준비가 잘 되어 "F5" 키를 눌러 실행하면 디버그 환경으로 파이썬 코드가 실행되고, 원하는 코드에 "F9" 키로 정지점(Breakpoint)를 걸어 테스트해 볼 수 있습니다.




Visual Studio 사용자들은, "F5" 실행뿐만 아니라 "Ctrl + F5(Start Without Debugging)" 기능도 당연히 바라게 됩니다. Visual Studio Code의 경우에는 그와 비슷한 걸로 "Ctrl+Shift+B" 키가 제공됩니다.

그런데, "Ctrl+Shift+B" 키를 누르면 "No task runner configured." 메시지가 나오고 우측에 "Configure Task Runner", "Close" 버튼이 보입니다.

vscode_run_1.png

"Configure Task Runner"를 누르면 다음과 같이 빌드 도구를 선택하는 메뉴가 뜨는데, 여기서 맨 아래인 "Others"를 선택합니다. (만약, 메뉴에 있는 환경이라면 그걸 선택해도 되지만, Python의 경우에는 없으므로.)

vscode_run_2.png

그럼, ".vscode" 폴더에 "tasks.json" 파일이 생성되며 Visual Studio Code에 로드됩니다.

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "0.1.0",
    "command": "echo",
    "isShellCommand": true,
    "args": ["Hello World"],
    "showOutput": "always"
}

"command"에 "python"을 입력하면, Visual Studio Code가 환경 변수 PATH에 연결된 python.exe를 실행시켜 줍니다. 그리고 "args"에는 실행될 파일의 .py 이름을 넣어주면 됩니다. 이 글에서는 "helloworld.py"이기 때문에 최종적으로 다음과 같이 구성해 줄 수 있습니다.

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "0.1.0",
    "command": "python",
    "isShellCommand": true,
    "args": ["helloworld.py"],
    "showOutput": "always"
}

그런데, 위와 같이 해주면 Visual Studio Code에서 다른 소스 코드 파일을 편집 중일 때도 Ctrl+Shift+B 키를 누르면 "helloworld.py" 소스 코드가 실행되는 문제가 있습니다. 따라서, "현재 편집 중인 파일"을 실행하라는 의미로 다음과 같이 "${file}"이라고 명시해주는 것이 더 낫습니다.

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "0.1.0",
    "command": "python",
    "isShellCommand": true,
    "args": ["${file}"],
    "showOutput": "always"
}

이후로 아무 편집 파일이나 열어놓고 실행하고 싶을 때 Ctrl+Shift+B 키를 눌러주면 됩니다.

tasks.json에 관한 좀 더 자세한 사항은 다음의 문서에서 찾을 수 있습니다.

Integrate with External Tools via Tasks
; http://code.visualstudio.com/docs/editor/tasks




Python 확장 도구를 선택한 이후부터, .py 소스 코드를 편집해 저장할 때마다 다음과 같이 Linter가 설치되지 않았다는 메시지가 나옵니다.

vscode_pylint_1.png

Linter pylint is not installed.

그래서 "Install pylint"를 눌러 pylint를 설치할 텐데, 그래도 계속해서 저렇게 linter가 설치되지 않았다는 메시지가 나옵니다. 이런 경우 pylint.exe에 대해 Visual Studio Code가 찾을 수 없기 때문인데, 이를 해결하려면 pylint.exe가 있는 폴더를 환경 변수인 PATH에 등록시켜 주거나, ".vscode" 폴더에 "settings.json" 파일을 만들고 그 안에 다음과 같이 pylintPath를 명시해 주면 됩니다.

vscode_pylint_2.png

{
    "python.linting.pylintPath": "${env.USERPROFILE}/AppData/Local/Programs/Python/Python35/Scripts/pylint.exe"
}

이런 식으로 pylint가 함께 사용되는 것은 이 글에서 설치한 (Don Jayamanne의) "Python" 확장 도구에 한해서입니다. 즉, 다른 확장 도구를 설치하면 lint 기능이 없을 수도 있고 lint 경로를 제공해주는 방법도 다를 수 있습니다. (Don Jayamanne의) "Python" 확장 도구에 대한 좀 더 자세한 설명은 다음의 문서에서 찾을 수 있습니다.

DonJayamanne/pythonVSCode 
; https://github.com/DonJayamanne/pythonVSCode/wiki




이 정도면... python을 Visual Studio Code에서 실습하는 데 크게 어려움은 없을 것입니다. ^^



db 연동 코드 조각과,

# pip install pymysql

import pymysql

dbURL = '...'
dbPort = 3306
dbUser = '..'
dbPass = '...'

conn = pymysql.connect(host=dbURL, port=dbPort, user=dbUser, passwd=dbPass, db='testdb',
    charset='utf8', use_unicode=True)

sql = "INSERT INTO test(name, age, addr) VALUES (%s, %s, %s);"
cur = conn.cursor()
cur.execute(sql, ("홍길동", "25", "서울"))
conn.commit()

sql = "SELECT * FROM testdb.test"
cur = conn.cursor()
cur.execute(sql)
result = cur.fetchall()
conn.commit()

print(result)
print(type(result))

conn.close()

크롤링 코드 조각!

# pip install beautifulsoup4

import urllib.request
import bs4

web_page = urllib.request.urlopen('https://www.naver.com')
result = bs4.BeautifulSoup(web_page, 'html.parser')
news_list = result.find_all('img', class_='news_logo')

for news in news_list:
    print(news['alt'], end=',')

/* 출력 결과
뉴시스,한겨레,스포탈코리아,헤럴드경제,뉴스타파,국민일보,KBS World,JTBC,지지통신,아이뉴스24,머니투데이,디지털타임스,노컷뉴스,문화일보,지디넷코리아,중부일보,기호일보,경인일보,법률신문,국방일보,머니에스,뉴스엔,법률방송뉴스,인벤,
*/



Django 기본 실습
// 설치
c:\temp> pip install Django

c:\temp> cd d:\mywork

// 기본 프로젝트 코드 생성
d:\mywork> django-admin startproject myapp

d:\mywork> cd myapp

// 실행
d:\mywork\myapp> python manage.py runserver 8000
Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).

You have 18 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.
August 05, 2021 - 10:35:17
Django version 3.2.6, using settings 'myapp.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

// Django 환경의 shell
// d:\mywork\myapp> python manage.py shell

// 프로젝트 내에 또 다른 app 생성
d:\mywork\myapp> python manage.py startapp bbs

/*
./myapp/settings.py에 "INSTALLED_APPS"에 "bbs" 추가

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'bbs'
]
*/

// model 및 view(Generic View - View, TemplateView, RedirectView, DetailView, ListView) 추가하고,

// 추가된 model에 대한 데이터베이스 scheme 만드는 python 스크립트 파일 생성 (nnnn_initial.py)
d:\mywork\myapp> python manage.py makemigrations

// /migrations 디렉터리에 있는 스크립트를 기반으로 한 물리적인 데이터베이스 scheme 동기화(settings.py에 지정된 DB 연결 문자열 정보 기반)
d:\mywork\myapp> python manage.py migrate

// 관리자 계정 설정
d:\mywork\myapp> python manage.py createsuperuser
Username (leave blank to use 'testusr'): testusr
Email address: testusr@test.com
Password:
Password (again):
Superuser created successfully.

// 관리자 계정 확인
// http://127.0.0.1:8000/admin

// virtualenv 설치
c:\temp> pip install virtualenv

// 새로운 virtualenv 생성
c:\temp> virtualenv myapp




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







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

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

비밀번호

댓글 작성자
 



2019-04-02 05시48분
[송상훈] vscode 에 대한 궁금증이 많이 해결되었습니다.
잘 보았습니다.
다른 것도 찾아 봐야겠습니다. ^^
[guest]
2021-01-07 09시05분
[손님2] 와 이 글 덕분에 문제를 해결했습니다. 정말 감사드립니다!! 앞으로 적게 일하고 많이 버시길 바랍니다
[guest]

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13600정성태4/18/2024271닷넷: 2242. C# - 관리 스레드와 비관리 스레드
13599정성태4/17/2024287닷넷: 2241. C# - WAV 파일의 PCM 사운드 재생(Windows Multimedia)파일 다운로드1
13598정성태4/16/2024316닷넷: 2240. C# - WAV 파일 포맷 + LIST 헤더파일 다운로드1
13597정성태4/15/2024385닷넷: 2239. C# - WAV 파일의 PCM 데이터 생성 및 출력파일 다운로드1
13596정성태4/14/2024761닷넷: 2238. C# - WAV 기본 파일 포맷파일 다운로드1
13595정성태4/13/2024879닷넷: 2237. C# - Audio 장치 열기 (Windows Multimedia, NAudio)파일 다운로드1
13594정성태4/12/20241010닷넷: 2236. C# - Audio 장치 열람 (Windows Multimedia, NAudio)파일 다운로드1
13593정성태4/8/20241050닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
13592정성태4/2/20241206C/C++: 165. CLion으로 만든 Rust Win32 DLL을 C#과 연동
13591정성태4/2/20241167닷넷: 2234. C# - WPF 응용 프로그램에 Blazor App 통합파일 다운로드1
13590정성태3/31/20241072Linux: 70. Python - uwsgi 응용 프로그램이 k8s 환경에서 OOM 발생하는 문제
13589정성태3/29/20241142닷넷: 2233. C# - 프로세스 CPU 사용량을 나타내는 성능 카운터와 Win32 API파일 다운로드1
13588정성태3/28/20241196닷넷: 2232. C# - Unity + 닷넷 App(WinForms/WPF) 간의 Named Pipe 통신파일 다운로드1
13587정성태3/27/20241154오류 유형: 900. Windows Update 오류 - 8024402C, 80070643
13586정성태3/27/20241296Windows: 263. Windows - 복구 파티션(Recovery Partition) 용량을 늘리는 방법
13585정성태3/26/20241094Windows: 262. PerformanceCounter의 InstanceName에 pid를 추가한 "Process V2"
13584정성태3/26/20241047개발 환경 구성: 708. Unity3D - C# Windows Forms / WPF Application에 통합하는 방법파일 다운로드1
13583정성태3/25/20241157Windows: 261. CPU Utilization이 100% 넘는 경우를 성능 카운터로 확인하는 방법
13582정성태3/19/20241417Windows: 260. CPU 사용률을 나타내는 2가지 수치 - 사용량(Usage)과 활용률(Utilization)파일 다운로드1
13581정성태3/18/20241586개발 환경 구성: 707. 빌드한 Unity3D 프로그램을 C++ Windows Application에 통합하는 방법
13580정성태3/15/20241136닷넷: 2231. C# - ReceiveTimeout, SendTimeout이 적용되지 않는 Socket await 비동기 호출파일 다운로드1
13579정성태3/13/20241493오류 유형: 899. HTTP Error 500.32 - ANCM Failed to Load dll
13578정성태3/11/20241628닷넷: 2230. C# - 덮어쓰기 가능한 환형 큐 (Circular queue)파일 다운로드1
13577정성태3/9/20241874닷넷: 2229. C# - 닷넷을 위한 난독화 도구 소개 (예: ConfuserEx)
13576정성태3/8/20241543닷넷: 2228. .NET Profiler - IMetaDataEmit2::DefineMethodSpec 사용법
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...