Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 306. Visual Studio Code에서 Python 개발 환경 구성 [링크 복사], [링크+제목 복사],
조회: 49108
글쓴 사람
정성태 (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]

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13893정성태2/27/20252211Linux: 115. eBPF (bpf2go) - ARRAY / HASH map 기본 사용법
13892정성태2/24/20252963닷넷: 2325. C# - PowerShell과 연동하는 방법파일 다운로드1
13891정성태2/23/20252490닷넷: 2324. C# - 프로세스의 성능 카운터용 인스턴스 이름을 구하는 방법파일 다운로드1
13890정성태2/21/20252316닷넷: 2323. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(Win32 API)파일 다운로드1
13889정성태2/20/20253039닷넷: 2322. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(성능 카운터, WMI) [1]파일 다운로드1
13888정성태2/17/20252483닷넷: 2321. Blazor에서 발생할 수 있는 async void 메서드의 부작용
13887정성태2/17/20253064닷넷: 2320. Blazor의 razor 페이지에서 code-behind 파일로 코드를 분리 및 DI 사용법
13886정성태2/15/20252572VS.NET IDE: 196. Visual Studio - Code-behind처럼 cs 파일을 그룹핑하는 방법
13885정성태2/14/20253230닷넷: 2319. ASP.NET Core Web API / Razor 페이지에서 발생할 수 있는 async void 메서드의 부작용
13884정성태2/13/20253503닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20253256닷넷: 2317. C# - Memory Mapped I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13882정성태2/10/20252577스크립트: 70. 파이썬 - oracledb 패키지 연동 시 Thin / Thick 모드
13881정성태2/7/20252823닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/20253167오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/20253389오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/20253182오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20253236닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
13876정성태1/25/20253691닷넷: 2314. C# - ProcessStartInfo 타입의 Arguments와 ArgumentList파일 다운로드1
13875정성태1/24/20253124스크립트: 69. 파이썬 - multiprocessing 패키지의 spawn 모드로 동작하는 uvicorn의 workers
13874정성태1/24/20253542스크립트: 68. 파이썬 - multiprocessing Pool의 기본 프로세스 시작 모드(spawn, fork)
13873정성태1/23/20252969디버깅 기술: 217. WinDbg - PCI 장치 열거파일 다운로드1
13872정성태1/23/20252881오류 유형: 944. WinDbg - 원격 커널 디버깅이 연결은 되지만 Break (Ctrl + Break) 키를 눌러도 멈추지 않는 현상
13871정성태1/22/20253291Windows: 278. Windows - 윈도우를 다른 모니터 화면으로 이동시키는 단축키 (Window + Shift + 화살표)
13870정성태1/18/20253731개발 환경 구성: 741. WinDbg - 네트워크 커널 디버깅이 가능한 NIC 카드 지원 확대
13869정성태1/18/20253453개발 환경 구성: 740. WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우
13868정성태1/17/20253109Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...