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

파이썬 - 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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  85  86  87  [88]  89  90  ...
NoWriterDateCnt.TitleFile(s)
11814정성태2/12/201919603오류 유형: 512. VM(가상 머신)의 NT 서비스들이 자동 시작되지 않는 문제
11813정성태2/12/201920323.NET Framework: 809. C# - ("Save File Dialog" 등의) 대화 창에 확장 속성을 보이는 방법
11812정성태2/11/201917776오류 유형: 511. Windows Server 2003 VM 부팅 후 로그인 시점에 0xC0000005 BSOD 발생
11811정성태2/11/201924668오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제
11810정성태2/11/201920565.NET Framework: 808. .NET Profiler - GAC 모듈에서 GAC 비-등록 모듈을 참조하는 경우의 문제
11809정성태2/11/201924062.NET Framework: 807. ClrMD를 이용해 메모리 덤프 파일로부터 특정 인스턴스를 참조하고 있는 소유자 확인
11808정성태2/8/201925719디버깅 기술: 123. windbg - 닷넷 응용 프로그램의 메모리 누수 분석
11807정성태1/29/201923451Windows: 156. 가상 디스크의 용량을 복구 파티션으로 인해 늘리지 못하는 경우 [4]
11806정성태1/29/201921580디버깅 기술: 122. windbg - 덤프 파일로부터 PID와 환경 변수 등의 정보를 구하는 방법
11805정성태1/28/201925236.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]파일 다운로드1
11804정성태1/24/201922606Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우
11803정성태1/10/201921580디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상
11802정성태1/7/201922967.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)파일 다운로드1
11801정성태1/1/201923789개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]
11800정성태12/28/201823301오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error파일 다운로드1
11799정성태12/19/201825954.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]파일 다운로드1
11798정성태12/19/201823942개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"
11797정성태12/19/201819189개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류
11796정성태12/19/201820947개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법
11795정성태12/19/201824613Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]
11794정성태12/16/201820334오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.
11793정성태12/16/201823256개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법 [1]
11792정성태12/11/201821156Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting파일 다운로드1
11791정성태12/11/201821472VS.NET IDE: 130. C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [1]
11790정성태12/11/201821086오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied.
11789정성태12/10/201836040Windows: 153. C# - USB 장치의 연결 및 해제 알림을 위한 WM_DEVICECHANGE 메시지 처리 [2]파일 다운로드2
... 76  77  78  79  80  81  82  83  84  85  86  87  [88]  89  90  ...