Microsoft MVP성태의 닷넷 이야기
스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일 [링크 복사], [링크+제목 복사],
조회: 422
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

파이썬 - Cython 기본 예제 및 컴파일

Cython은 프로그래밍 언어인데요, 이름에서 의미하듯이 "C + Python"에 준하는 성격을 갖습니다. 구문은 대체로 파이썬으로 유지되는데 C 언어와 상호 연동할 수 있는 다양한 방법을 제공합니다. 즉, 파이썬의 쉬운 구문을 장점으로 유지하면서 컴파일을 C 언어 수준으로 제공하는데, 이를 통해 성능이 요구되는 부분을 Cython으로 포팅해 확장 모듈로 제공할 수 있습니다.

간단하게 실습을 해볼까요? ^^

이를 위해 우선 Cython 모듈을 설치한 다음,

$ python3 -m pip install Cython
Collecting Cython
  Downloading cython-3.1.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.2 MB)
     |████████████████████████████████| 3.2 MB 5.0 MB/s
Installing collected packages: Cython
Successfully installed Cython-3.1.0

예제 정도 수준의 (관례상 pyx 확장자를 갖는) Cython 소스 코드를 만들고,

# my_test.pyx

def sum(int a, int b):
    return a + b

이것을 컴파일하는 setup.py를 작성합니다.

# setup.py 

from distutils.core import setup
from Cython.Build import cythonize
setup( ext_modules = cythonize("my_test.pyx") )

마지막으로 저 setup.py를 실행해 주면,

$ python3 setup.py build_ext --inplace
Compiling my_test.pyx because it changed.
[1/1] Cythonizing my_test.pyx
running build_ext
building 'my_test' extension
creating build
creating build/temp.linux-x86_64-3.8
x86_64-linux-gnu-gcc -pthread -Wno-unused-result -Wsign-compare -DNDEBUG -g -fwrapv -O2 -Wall -g -fstack-protector-strong -Wformat -Werror=format-security -g -fwrapv -O2 -g -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2 -fPIC -I/usr/include/python3.8 -c my_test.c -o build/temp.linux-x86_64-3.8/my_test.o
x86_64-linux-gnu-gcc -pthread -shared -Wl,-O1 -Wl,-Bsymbolic-functions -Wl,-Bsymbolic-functions -Wl,-z,relro -g -fwrapv -O2 -Wl,-Bsymbolic-functions -Wl,-z,relro -g -fwrapv -O2 -g -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2 build/temp.linux-x86_64-3.8/my_test.o -o /mnt/c/temp/my_test.cpython-38-x86_64-linux-gnu.so

// 이하 의존성 및 symbol 확인

$ ldd my_test.cpython-38-x86_64-linux-gnu.so
        linux-vdso.so.1 (0x00007ffc41fb6000)
        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f5bbf992000)
        /lib64/ld-linux-x86-64.so.2 (0x00007f5bbfba7000)

$ nm my_test.cpython-38-x86_64-linux-gnu.so  | grep sum
0000000000008959 r __pyx_k_sum
000000000000b800 d __pyx_mdef_7my_test_1sum
0000000000006290 t __pyx_pw_7my_test_1sum

구문은 파이썬 구문이지만, 내부적으로 gcc 컴파일러를 거칠 수 있도록 C 언어로 변환됩니다. 따라서, 당연히 C 언어를 빌드했을 때처럼 ./build/temp.linux-x86_64-3.8/my_test.o 이름의 object 파일과 "my_test.cpython-38-x86_64-linux-gnu.so"라는 이름의 공유 라이브러리 파일이 생성됩니다.

끝입니다. 이제 Python에서 해당 모듈을 import해 사용할 수 있습니다.

$ python3
Python 3.8.10 (default, Mar 18 2025, 20:04:55)
[GCC 9.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import my_test
>>> my_test.sum(5, 6)
11
>>> print(my_test.__file__)
/mnt/c/temp/my_test.cpython-38-x86_64-linux-gnu.so

사실 복잡한 수준으로 확장 기능을 제공해야 한다면 Cython보다는 직접 C/C++ 언어로 만드는 것이 더 쉬울 수 있습니다. 단지, 기존 Python으로 작성한 코드 중 성능을 요구해야 한다면 점진적으로 Cython으로 포팅할 수 있다는 장점이 무척이나 매력적인 언어라고 할 수 있겠습니다. ^^




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







[최초 등록일: ]
[최종 수정일: 5/17/2025]

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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  [101]  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11416정성태12/21/201719723.NET Framework: 718. AsyncTaskMethodBuilder.Create() 메서드 동작 방식 [2]
11415정성태12/21/201721510.NET Framework: 717. Task를 포함하지 않는 async 메서드의 동작 방식 [6]
11414정성태12/21/201728579.NET Framework: 716. async 메서드의 void 반환 타입 사용에 대하여파일 다운로드2
11413정성태12/20/201723036개발 환경 구성: 344. 윈도우 10 - TTS 및 음성 인식을 위한 환경 설정
11412정성태12/20/201725580.NET Framework: 715. C# - Windows 10 운영체제의 데스크톱 앱에서 TTS(SpeechSynthesizer) 사용하는 방법 [1]파일 다운로드1
11411정성태12/20/201723895사물인터넷: 15. 라즈베리 파이용 C++ 프로젝트에 SSL Socket 적용
11410정성태12/20/201736236.NET Framework: 714. SSL Socket 예제 - C/C++ 서버, C# 클라이언트 [1]파일 다운로드1
11409정성태12/18/201742335VC++: 122. 오픈 소스 라이브러리를 쉽게 빌드해 주는 "C++ Package Manager for Windows: vcpkg" [7]
11408정성태12/18/201721599.NET Framework: 713. C# - SharpDX + DXGI를 이용한 윈도우 화면 캡처 소스 코드 + Direct2D 출력 + OpenCV (2)파일 다운로드1
11407정성태12/18/201724842.NET Framework: 712. C# - SharpDX + DXGI를 이용한 윈도우 화면 캡처 소스 코드 + Direct2D 출력 + OpenCV [1]파일 다운로드1
11406정성태12/17/201747234.NET Framework: 711. C# - OpenCvSharp의 Mat 데이터 조작 방법 [5]파일 다운로드1
11405정성태12/17/201743247.NET Framework: 710. C# - OpenCvSharp을 이용한 Webcam 영상 처리 + Direct2D [1]파일 다운로드1
11404정성태12/16/201730466.NET Framework: 709. C# - OpenCvSharp을 이용한 동영상(avi, mp4, ...) 처리 + Direct2D [7]파일 다운로드1
11403정성태12/16/201732829.NET Framework: 708. C# - OpenCvSharp을 이용한 동영상(avi, mp4, ...) 처리 [3]파일 다운로드1
11402정성태12/15/201737822.NET Framework: 707. OpenCV 응용 프로그램을 C#으로 구현 - OpenCvSharp [2]파일 다운로드1
11401정성태12/15/201726478.NET Framework: 706. C# - SharpDX + DXGI를 이용한 윈도우 화면 캡처 소스 코드 + Direct2D 출력 [2]파일 다운로드1
11400정성태12/14/201729661.NET Framework: 705. C# - SharpDX + DXGI를 이용한 윈도우 화면 캡처 소스 코드 [9]파일 다운로드1
11399정성태12/13/201718155.NET Framework: 704. Win32 API의 UnionRect를 닷넷 BCL의 Rectangle.Union으로 바꿀 때 주의 사항
11398정성태12/13/201718242오류 유형: 442. ASP.NET Core Web Application (on .NET Framework) 프로젝트에서 외부 라이브러리 동적 로드 시 런타임 버전 문제파일 다운로드1
11397정성태12/12/201720885.NET Framework: 703. 양자 컴퓨팅을 위한 마이크로소프트의 Q# 언어
11396정성태12/8/201743264개발 환경 구성: 343. Visual Studio - 리눅스 용 프로젝트의 인텔리센스를 위한 헤더 파일 처리 방법 [3]
11395정성태12/8/201718976오류 유형: 441. 이벤트 로그 - Time Provider NtpClient: No valid response has been received from domain controller
11394정성태12/8/201718611개발 환경 구성: 342. 비주얼 스튜디오에서 실행하던 ASP.NET Core (.NET Framework) 응용 프로그램을 명령행에서 실행하는 방법
11393정성태12/7/201723347Windows: 145. 윈도우 10 빌드 17046부터 WSL에서 백그라운드 작업 지원 [5]
11392정성태12/7/201718338개발 환경 구성: 341. openSUSE에 닷넷 코어 설치
11391정성태12/7/201721288개발 환경 구성: 340. WSL을 이용해 윈도우 PC 1대에서 openSUSE 응용 프로그램을 Visual Studio로 개발하는 방법 [1]
... 91  92  93  94  95  96  97  98  99  100  [101]  102  103  104  105  ...