日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python转cpython_cpython的使用

發布時間:2024/3/24 python 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python转cpython_cpython的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這個的學習主要是因為在運行目標檢測的代碼時總是會出現下面的錯誤:

fromCython.Build import cythonize

ModuleNotFoundError: No module named'Cython'

----------------------------------------ERROR: Command erroredout with exit status 1: python setup.py egg_info Check the logs for full command output.

安裝:

pip install Cython

Collecting Cython

Downloading Cython-0.29.19-cp37-cp37m-macosx_10_9_x86_64.whl (1.9 MB)

所以打算學學這個模塊是怎么用的,以及用在哪里的

https://github.com/Sean16SYSU/CPython-Tutorial-zh

Python有時候太慢,如果手動編譯C或者是C++來寫#include的文件也比較麻煩。 CPython無疑是一個比較好的選擇。

改進的理由

每一行的計算量很少,因此python解釋器的開銷就會變的很重要。

數據的局部性原理:很可能是,當使用C的時候,更多的數據可以塞進CPU的cache中,因為Python的元素都是Object,而每個Object都是通過字典實現的,cache對這個數據不很友好。

項目

Hello World項目

第一個項目是Hello world。

創建一個文件helloworld.pyx,內容如下:

print("Hello world!")

保存后,創建setup.py文件,內容如下:

fromdistutils.core import setupfromCython.Build import cythonize

setup(

ext_modules= cythonize("helloworld.pyx")

)

保存后,命令行進入setup.py所在目錄,并輸入python setup.py build_ext --inplace,如下:

$python setup.py build_ext --inplace

Compiling helloworld.pyx because it changed.

[1/1] Cythonizing helloworld.pyx/anaconda3/envs/deeplearning/lib/python3.7/site-packages/Cython/Compiler/Main.py:369: FutureWarning: Cython directive 'language_level' not set, using 2 for now (Py2). This will change in a later release! File: /Users/user/pytorch/NLP學習/learning_2.0/helloworld.pyx

tree=Parsing.p_module(s, pxd, full_module_name)

running build_ext

building'helloworld'extension

creating build

creating build/temp.macosx-10.9-x86_64-3.7gcc-Wno-unused-result -Wsign-compare -Wunreachable-code -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -I/anaconda3/envs/deeplearning/include -arch x86_64 -I/anaconda3/envs/deeplearning/include -arch x86_64 -I/anaconda3/envs/deeplearning/include/python3.7m -c helloworld.c -o build/temp.macosx-10.9-x86_64-3.7/helloworld.o

gcc-bundle -undefined dynamic_lookup -L/anaconda3/envs/deeplearning/lib -arch x86_64 -L/anaconda3/envs/deeplearning/lib -arch x86_64 -arch x86_64 build/temp.macosx-10.9-x86_64-3.7/helloworld.o -o /Users/user/pytorch/NLP學習/learning_2.0/helloworld.cpython-37m-darwin.so

運行完這個命令后,該目錄下就會生成三個文件:

build helloworld.pyx

helloworld.c setup.py

helloworld.cpython-37m-darwin.so

然后創建一個調用文件test.py,內容為:

import helloworld

運行返回:

i$ python test.py

Hello world!

.pyx文件:

pyx文件是python的c擴展文件,代碼要符合cython的規范,用什么編輯器寫都行。我在eric4上寫的,結果它默認用python解釋器來進行解釋,還提示有bug,“語法錯誤”。

上面的pyx文件還僅僅是源代碼文件,要想被python調用、要想運行,僅僅寫了源代碼還是不夠的(不像 Python 語言可直接解釋使用的 .py 文件,.pyx 文件必須先被編譯成 .c 文件,再編譯成 .pyd (Windows 平臺) 或 .so (Linux 平臺) 文件,才可作為模塊 import 導入使用)。具體來說,還要轉成.c或者.c++的文件,并且再進一步轉成.pyd文件。pyd文件才是可以直接使用的文件。為了達到上述目的,就要寫一個setup.py腳本,如上面那種

上述兩個步驟,相當于把某個python效率瓶頸模塊(這之前需要用profile工具來定位)用效率更高的代碼寫成了python的c擴展形式,接下來,就是要在python代碼中調用他們。test.py就是這個調用的腳本

Fibonacci Function項目

斐波那契數列:1, 1, 2, 3, 5,... 前兩位為1,之后每個數等于前面兩個數之和。

創建fib.pyx,內容如下:

from__future__ import print_function

def fib(n):

a, b= 0, 1

while b

print(b, end=' ')

a, b= b, a+b

print()

創建setup.py文件,內容如下:

fromdistutils.core import setupfromCython.Build import cythonize

setup(

ext_modules= cythonize("fib.pyx")

)

通過命令python setup.py build_ext --inplace,生成出來的文件:

python setup.py build_ext --inplace

Compiling fib.pyx because it changed.

[1/1] Cythonizing fib.pyx/anaconda3/envs/deeplearning/lib/python3.7/site-packages/Cython/Compiler/Main.py:369: FutureWarning: Cython directive 'language_level' not set, using 2 for now (Py2). This will change in a later release! File: /Users/user/pytorch/NLP學習/learning_2.0/fib.pyx

tree=Parsing.p_module(s, pxd, full_module_name)

running build_ext

building'fib'extension

gcc-Wno-unused-result -Wsign-compare -Wunreachable-code -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -I/anaconda3/envs/deeplearning/include -arch x86_64 -I/anaconda3/envs/deeplearning/include -arch x86_64 -I/anaconda3/envs/deeplearning/include/python3.7m -c fib.c -o build/temp.macosx-10.9-x86_64-3.7/fib.o

gcc-bundle -undefined dynamic_lookup -L/anaconda3/envs/deeplearning/lib -arch x86_64 -L/anaconda3/envs/deeplearning/lib -arch x86_64 -arch x86_64 build/temp.macosx-10.9-x86_64-3.7/fib.o -o /Users/user/pytorch/NLP學習/learning_2.0/fib.cpython-37m-darwin.so

測試test.py:

import fib

fib.fib(100)

返回:

$ python test.py1 1 2 3 5 8 13 21 34 55 89

如果輸出兩者的時間:

(deeplearning) userdeMacBook-Pro:learning_2.0user$ python fib.pyx1 1 2 3 5 8 13 21 34 55 89

5.7220458984375e-05(deeplearning) userdeMacBook-Pro:learning_2.0user$ python test.py1 1 2 3 5 8 13 21 34 55 89

5.793571472167969e-05

發現速度并沒有很高的提升,很可能是操作本來就很簡單,數值也很小,沒什么優化的空間了。

Primes項目

給一個數值n,輸出前n個質數(list)。

寫到primes.pyx中:

def primes(intnb_primes):

cdefintn, i, len_p

cdefint p[1000]if nb_primes > 1000:

nb_primes= 1000len_p= 0n= 2

while len_p

else:

p[len_p]=n

len_p+= 1n+= 1result_as_list= [prime for prime inp[:len_p]]return result_as_list

setup.py:

fromdistutils.core import setupfromCython.Build import cythonize

setup(

ext_modules= cythonize("primes.pyx")

)

test.py:

import primes

import time

time0=time.time()

primes.primes(10000)

print(time.time()- time0)

返回使用時間:

0.0017080307006835938

View Code

prime.py原來:

def primes(nb_primes):

p=[]if nb_primes > 1000:

nb_primes= 1000n= 2

while len(p)

else:

p.append(n)

n+= 1result_as_list= [prime for prime inp]returnresult_as_listif __name__ == '__main__':

import time

time0=time.time()

primes(10000)

print(time.time()- time0)

使用時間:

0.030839204788208008

可見的確快了不少!!!!!!

總結

以上是生活随笔為你收集整理的python转cpython_cpython的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。