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

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




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/20/2024]

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]

... 121  [122]  123  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10873정성태11/25/201525492.NET Framework: 540. C# - 부동 소수 계산 왜 이렇게 나오죠? (2) [3]파일 다운로드1
10872정성태11/24/201532501.NET Framework: 539. C# - 부동 소수 계산 왜 이렇게 나오죠? (1) [1]
10871정성태11/23/201528112오류 유형: 313. SignTool Error: No certificates were found that met all the given criteria.
10870정성태11/23/201528973오류 유형: 312. 윈도우 10 TH2 (버전 1511) 업데이트가 안되는 경우 [1]
10869정성태11/23/201524766오류 유형: 311. certutil 실행 오류 - 0x80070057 [1]
10868정성태11/20/201524633제니퍼 .NET: 25. 제니퍼 닷넷 적용 사례 (5) - RestSharp 라이브러리의 CPU High 현상파일 다운로드1
10867정성태10/18/201527186.NET Framework: 538. Thread.Abort로 인해 프로세스가 종료되는 현상
10866정성태10/14/201523384.NET Framework: 537. C# - Reflection의 박싱 없이 값 형식을 다루는 방법파일 다운로드1
10865정성태10/13/201523156.NET Framework: 536. Thread.Abort의 스레드 종료 지연파일 다운로드1
10864정성태10/12/201521378.NET Framework: 535. aspnet.config 파일의 설정을 읽는 방법
10863정성태10/9/201526185.NET Framework: 534. ASP.NET 응용 프로그램이 예외로 프로세스가 종료된다면?
10862정성태10/9/201524509오류 유형: 310. 비주얼 스튜디오 - Unspecified error (Exception from HRESULT: 0x80004005 (E_FAIL))
10861정성태10/9/201529183기타: 54. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 (2)
10860정성태10/5/201526627개발 환경 구성: 277. IIS AppPool의 시작/중단에 대한 이벤트 로그 확인 방법
10859정성태10/5/201527817.NET Framework: 533. C#에서 string 형식이 primitive일까요? [6]
10858정성태10/2/201524349VS.NET IDE: 105. Visual Studio의 단위 테스트 작성 시 Fakes를 이용한 메서드 재정의 방법 [1]파일 다운로드1
10857정성태10/1/201520352VS.NET IDE: 104. Visual C++ 프로젝트의 빌드 이벤트에서 환경 변수 사용하는 방법
10856정성태9/30/201531667.NET Framework: 532. WPF DataGrid의 데이터 바인딩 시 리플렉션의 부하는 어느 정도일까요?파일 다운로드1
10855정성태9/30/201521309.NET Framework: 531. C# - XSLT 내의 javascript에 전달한 XML 노드의 타입은?
10854정성태9/30/201521837오류 유형: 309. C# - 포인터를 쓰는 경우 VerificationException이 발생한다면?
10853정성태9/21/201519573오류 유형: 308. 공백 문자를 포함한 계정명의 권한으로 Visual Studio 확장을 설치할 때 오류 발생
10852정성태9/17/201524592VC++: 92. C++ 생성자를 DLL로부터 동적 로드해 객체를 생성한다면? [2]파일 다운로드1
10851정성태9/15/201524313.NET Framework: 530. C# - 중위식을 후위식으로 변환하는 예제파일 다운로드1
10850정성태9/14/201522964.NET Framework: 529. C# - volatile 키워드로 인한 차이점을 발생시키는 예제 [1]파일 다운로드1
10849정성태9/14/201557099오류 유형: 307. CLR20r3 오류 해결을 위해 mscorlib.dll을 덮어쓸때 주의할 점 [12]
10848정성태9/8/201527472VS.NET IDE: 103. Visual Studio의 Ctrl + F5 실행 동작파일 다운로드1
... 121  [122]  123  124  125  126  127  128  129  130  131  132  133  134  135  ...