• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            Python 中的pyc文件的用途

            Posted on 2011-08-12 21:41 RTY 閱讀(2690) 評論(0)  編輯 收藏 引用 所屬分類: Python
            引用別人的文章:

            什么是pyc文件
            pyc是一種二進(jìn)制文件,是由py文件經(jīng)過編譯后,生成的文件,是一種byte code,py文件變成pyc文件后,加載的速度有所提高,而且pyc是一種跨平臺(tái)的字節(jié)碼,是由python的虛擬機(jī)來執(zhí)行的,這個(gè)是類似于JAVA或者.NET的虛擬機(jī)的概念。pyc的內(nèi)容,是跟python的版本相關(guān)的,不同版本編譯后的pyc文件是不同的,
            2.5編譯的pyc文件,2.4版本的python是無法執(zhí)行的。
            為什么需要pyc文件
            這個(gè)需求太明顯了,因?yàn)閜y文件是可以直接看到源碼的,如果你是開發(fā)商業(yè)軟件的話,不可能把源碼也泄漏出去吧?所以就需要編譯為pyc后,再發(fā)布出去。當(dāng)然,pyc文件也是可以反編譯的,不同版本編譯后的pyc文件是不同的,根據(jù)python源碼中提供的opcode,可以根據(jù)pyc文件反編譯出py文件源碼,網(wǎng)上可以找到一個(gè)反編譯python2.3版本的pyc文件的工具,不過該工具從python2.4開始就要收費(fèi)了,如果需要反編譯出新版本的pyc文件的話,就需要自己動(dòng)手了(俺暫時(shí)還沒這能力
            ^--^),不過你可以自己修改python的源代碼中的opcode文件,重新編譯python,從而防止不法分子的破解。
            生成單個(gè)pyc文件
            python就是個(gè)好東西,它提供了內(nèi)置的類庫來實(shí)現(xiàn)把py文件編譯為pyc文件,這個(gè)模塊就是 py_compile 模塊。
            使用方法非常簡單,如下所示,直接在idle中,就可以把一個(gè)py文件編譯為pyc文件了。(假設(shè)在windows環(huán)境下)
             
            import py_compile
            py_compile.compile(r
            'H:/game/test.py')
             
            compile函數(shù)原型:
            compile(file[, cfile[, dfile[, doraise]]])
            file 表示需要編譯的py文件的路徑
            cfile 表示編譯后的pyc文件名稱和路徑,默認(rèn)為直接在file文件名后加c 或者 o,o表示優(yōu)化的字節(jié)碼
            dfile 這個(gè)參數(shù)英文看不明白,請各位大大賜教。(鄙視下自己)原文:it 
            is used as the name of the source file in error messages instead of file
            doraise 可以是兩個(gè)值,True或者False,如果為True,則會(huì)引發(fā)一個(gè)PyCompileError,否則如果編譯文件出錯(cuò),則會(huì)有一個(gè)錯(cuò)誤,默認(rèn)顯示在sys.stderr中,而不會(huì)引發(fā)異常
            (來自python2.5文檔)
            批量生成pyc文件
            一般來說,我們的工程都是在一個(gè)目錄下的,一般不會(huì)說僅僅編譯一個(gè)py文件而已,而是需要把整個(gè)文件夾下的py文件都編譯為pyc文件,python又為了我們提供了另一個(gè)模塊:compileall 。使用方法如下:
             
            import compileall
            compileall.compile_dir(r
            'H:/game')
            這樣就把game目錄,以及其子目錄下的py文件編譯為pyc文件了。嘿嘿,夠方便吧。來看下compile_dir函數(shù)的說明:
             
            compile_dir(dir[, maxlevels[, ddir[, force[, rx[, quiet]]]]])
            dir 表示需要編譯的文件夾位置
            maxlevels 表示需要遞歸編譯的子目錄的層數(shù),默認(rèn)是10層,即默認(rèn)會(huì)把10層子目錄中的py文件編譯為pyc
            ddir 英文沒明白,原文:it 
            is used as the base path from which the filenames used in error messages will be generated。
            force 如果為True,則會(huì)強(qiáng)制編譯為pyc,即使現(xiàn)在的pyc文件是最新的,還會(huì)強(qiáng)制編譯一次,pyc文件中包含有時(shí)間戳,python編譯器會(huì)根據(jù)時(shí)間來決定,是否需要重新生成一次pyc文件
            rx 表示一個(gè)正則表達(dá)式,比如可以排除掉不想要的目錄,或者只有符合條件的目錄才進(jìn)行編譯
            quiet 如果為True,則編譯后,不會(huì)在標(biāo)準(zhǔn)輸出中,打印出信息
            (來自python2.5文檔)
            總結(jié)
            通過上面的方法,可以方便的把py文件編譯為pyc文件了,從而可以實(shí)現(xiàn)部分的源碼隱藏,保證了python做商業(yè)化軟件時(shí),保證了部分的安全性吧,繼續(xù)學(xué)習(xí)下,看怎么修改opcode。


            我這里的說明,例如,我當(dāng)前有如下文件:
            example.pyc
            runme.py

            runme.py 調(diào)用的是example.py 文件,但是當(dāng)前只有pyc文件,那么是不是不可以正常運(yùn)行呢,答案是:不是的。是可以運(yùn)行的。 這就是為什么pyc可以用作保密的原因。






            久久青草国产精品一区| 亚洲av日韩精品久久久久久a| 久久精品麻豆日日躁夜夜躁| 日韩精品久久久肉伦网站| 国产精品久久久福利| 久久九九亚洲精品| 最新久久免费视频| 日韩久久久久久中文人妻| 国产99久久九九精品无码| 一级女性全黄久久生活片免费 | 久久伊人五月天论坛| 亚洲国产成人精品女人久久久| 少妇熟女久久综合网色欲| 欧美精品久久久久久久自慰| 精品久久久久久久久久久久久久久| 欧美精品一区二区久久| 99精品久久久久中文字幕| 亚洲精品无码久久久| 国产成人精品久久一区二区三区| 久久精品国产一区二区三区| 久久亚洲AV成人无码电影| 欧洲国产伦久久久久久久| 久久er热视频在这里精品| 国产精品久久久久久久久久影院| 日本久久久精品中文字幕| 亚洲乱码中文字幕久久孕妇黑人| 久久精品无码一区二区日韩AV| 精品蜜臀久久久久99网站| 久久国产免费直播| 狠狠色丁香久久婷婷综合图片| 精品综合久久久久久88小说| 欧美精品一本久久男人的天堂| 久久久久亚洲av无码专区导航| 久久受www免费人成_看片中文| 久久综合伊人77777麻豆| 久久精品成人一区二区三区| 伊人丁香狠狠色综合久久| 国产精品久久久久久久久免费| 国产69精品久久久久777| 精品午夜久久福利大片| 久久福利青草精品资源站|