Microsoft MVP성태의 닷넷 이야기
스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일 [링크 복사], [링크+제목 복사],
조회: 3626
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11102정성태11/8/201622404오류 유형: 369. PeerFinder.FindAllPeersAsync 호출 시 System.UnauthorizedAccessException 예외 발생
11101정성태11/8/201623796.NET Framework: 621. 닷넷 프로파일러의 오류 코드 - 0x80131363
11100정성태11/7/201632466개발 환경 구성: 304. Wi-Fi Direct 지원 여부 확인 방법 [1]
11099정성태11/7/201634406.NET Framework: 620. C#에서 C/C++ 함수로 콜백 함수를 전달하는 예제 코드파일 다운로드1
11098정성태11/7/201623449오류 유형: 368. 빌드 이벤트에서 robocopy 사용 시 $(TargetDir) 매크로를 지정하는 경우 오류 발생
11097정성태11/7/201626258오류 유형: 367. go install: no install location for directory [...경로...] outside GOPATH
11096정성태11/6/201629296디버깅 기술: 83. PDB 파일을 수동으로 다운로드하는 방법
11095정성태11/6/201626695.NET Framework: 619. C# - Cognitive Services 중의 하나인 Face API를 사용해 얼굴 인식 및 흐림(blur) 효과 적용 [1]파일 다운로드1
11094정성태11/5/201628192VC++: 105. Visual Studio 2013/2015 - Ceemple OpenCV 확장을 이용한 웹캠 영상 출력
11093정성태11/4/201628127웹: 34. Edge 브라우저도 지원하는 클립보드 복사를 위한 자바스크립트 코드
11092정성태11/3/201635367.NET Framework: 618. C# - NAudio를 이용한 MP3 파일 재생 [5]파일 다운로드1
11091정성태11/3/201628257VC++: 104. std::call_once를 이용해 thread-safe한 Singleton 객체 생성파일 다운로드1
11090정성태11/1/201629713VC++: 103. C++ CreateTimerQueue, CreateTimerQueueTimer 예제 코드 [9]파일 다운로드1
11089정성태11/1/201630251디버깅 기술: 82. Windows 10을 위한 Symbol(PDB) 파일 내려받는 방법 [2]
11088정성태11/1/201632603.NET Framework: 617. C# - AForge.NET을 이용한 MP4 동영상 파일 재생 [7]파일 다운로드1
11087정성태11/1/201626738.NET Framework: 616. AForge.Video.FFMPEG를 최신 버전의 ffmpeg 파일로 의존성을 변경하는 방법파일 다운로드1
11086정성태11/1/201621630오류 유형: 366. The Microsoft Passport Container service terminated with the following error: General access denied error
11085정성태10/27/201636991.NET Framework: 615. C# - AForge.NET을 이용한 웹캠 영상 출력 [2]파일 다운로드1
11084정성태10/26/201624357오류 유형: 365. The User Profile Service service failed to the sign-in.
11083정성태10/26/201630654Windows: 131. 윈도우 10에서 사라진 "Adapters and Bindings" 네트워크 우선 순위 조정 기능 [1]
11082정성태10/26/201633659.NET Framework: 614. C# - DateTime.Ticks의 정밀도 [4]파일 다운로드1
11081정성태10/26/201623030오류 유형: 364. You need to fix your Microsoft Account for apps on your other devices to be able to launch apps and continue experiences on this device.
11080정성태10/24/201627089Windows: 130. Windows Server 2016 Nano 서버 설치 방법
11079정성태10/21/201624187Windows: 129. Windows Server 2016 설치 CD에 있는 Convert-WindowsImage.ps1 사용 방법 정리
11078정성태10/21/201625396Windows: 128. Windows Server 2016 Nano 서버 VHD 이미지 만드는 방법 - TP5 기준
11077정성태10/21/201623246오류 유형: 363. Active Directory 서버의 NETLOGON 서비스가 멈췄을 때 발생하는 문제
... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...