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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13707정성태8/6/20248365닷넷: 2292. C# - 자식 프로세스의 출력이 4,096보다 많은 경우 Process.WaitForExit 호출 시 hang 현상파일 다운로드1
13706정성태8/5/20248283개발 환경 구성: 718. Hyper-V - 리눅스 VM에 새로운 디스크 추가
13705정성태8/4/20248522닷넷: 2291. C# 13 - (5) params 인자 타입으로 컬렉션 허용 [2]파일 다운로드1
13704정성태8/2/20248847닷넷: 2290. C# - 간이 dotnet-dump 프로그램 만들기파일 다운로드1
13703정성태8/1/20247762닷넷: 2289. "dotnet-dump ps" 명령어가 닷넷 프로세스를 찾는 방법
13702정성태7/31/20248557닷넷: 2288. Collection 식을 지원하는 사용자 정의 타입을 CollectionBuilder 특성으로 성능 보완파일 다운로드1
13701정성태7/30/20248776닷넷: 2287. C# 13 - (4) Indexer를 이용한 개체 초기화 구문에서 System.Index 연산자 허용파일 다운로드1
13700정성태7/29/20248504디버깅 기술: 200. DLL Export/Import의 Hint 의미
13699정성태7/27/20248803닷넷: 2286. C# 13 - (3) Monitor를 대체할 Lock 타입파일 다운로드1
13698정성태7/27/20248680닷넷: 2285. C# - async 메서드에서의 System.Threading.Lock 잠금 처리파일 다운로드1
13697정성태7/26/20248234닷넷: 2284. C# - async 메서드에서의 lock/Monitor.Enter/Exit 잠금 처리파일 다운로드1
13696정성태7/26/20247850오류 유형: 920. dotnet publish - error NETSDK1047: Assets file '...\obj\project.assets.json' doesn't have a target for '...'
13695정성태7/25/20248062닷넷: 2283. C# - Lock / Wait 상태에서도 STA COM 메서드 호출 처리파일 다운로드1
13694정성태7/25/20248363닷넷: 2282. C# - ASP.NET Core Web App의 Request 용량 상한값 (Kestrel, IIS)
13693정성태7/24/20247585개발 환경 구성: 717. Visual Studio - C# 프로젝트에서 레지스트리에 등록하지 않은 COM 개체 참조 및 사용 방법파일 다운로드1
13692정성태7/24/20248557디버깅 기술: 199. Windbg - 리눅스에서 뜬 닷넷 응용 프로그램 덤프 파일에 포함된 DLL의 Export Directory 탐색
13691정성태7/23/20247743디버깅 기술: 198. Windbg - 스레드의 Win32 Message Queue 정보 조회
13690정성태7/23/20247350오류 유형: 919. Visual C++ 리눅스 프로젝트 - error : ‘u8’ was not declared in this scope
13689정성태7/22/20249022디버깅 기술: 197. Windbg - PE 포맷의 Export Directory 탐색
13688정성태7/21/20247993닷넷: 2281. C# - Lock / Wait 상태에서도 일부 Win32 메시지 처리파일 다운로드1
13687정성태7/19/20248485닷넷: 2280. C# - PostThreadMessage로 보낸 메시지를 Windows Forms에서 수신하는 방법파일 다운로드1
13686정성태7/19/20248296오류 유형: 918. Visual Studio - ATL Simple Object 추가 시 error C2065: 'IDR_...': undeclared identifier
13685정성태7/19/20248357스크립트: 66. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법 - 두 번째 이야기
13684정성태7/19/20248618닷넷: 2279. C# - 문자열 보간식 사례 (예: 조건 연산자 사용)
13683정성태7/18/20248026오류 유형: 917. ClrMD - Linux 환경의 .NET 5 덤프 분석 시 hang 현상
13682정성태7/18/20248324닷넷: 2278. WPF - 스레드에 종속되는 DependencyObject파일 다운로드1
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...