溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python3+PyInstall+Sciter中報錯缺少dll、html等文件怎么辦

發(fā)布時間:2021-07-12 13:39:26 來源:億速云 閱讀:183 作者:小新 欄目:開發(fā)技術

這篇文章將為大家詳細講解有關Python3+PyInstall+Sciter中報錯缺少dll、html等文件怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1 調(diào)試過程

用Python3.6+Sciter+PyCharm寫了一個py測試腳本helloworld.py,該腳本中只含有一條語句“import sciter”。在PyCharm中運行之,未報錯。

#helloworld.py
import sciter

然后將該腳本用PyInstaller打包成exe文件,打包程序pack.py如下:

#pack.py
from PyInstaller.__main__ import run
if __name__ == '__main__':
  opts = [
      # 字符串前加“r”,防止字符轉義
      # r'--hidden-import=py4j.java_collections',\
      # 要打包的Python文件
      r'D:\work\python\my_editor\helloworld\helloworld.py',\
      # -F, –onefile 打包一個單個文件,如果你的代碼都寫在一個.py文件的話,可以用這個,如果是多個.py文件就別用
      # '-F',\
      # -w:制作窗口程序,與之相對的-c意味制作命令行程序(默認)。--distpath指定打包的目的地路徑
      r'-w','--distpath=D:\work\python\my_editor\helloworld\dist',\
      # --workpath 指定工作路徑
      r'--workpath=D:\work\python\my_editor\helloworld\out',\
      # --specpath指定.spec文件保存路徑
      r'--specpath=D:\work\python\my_editor\helloworld\out',\
      # --icon 指定exe文件的圖標
      r'--icon=D:\work\python\my_editor\ico\text.ico',\
      # --upx-dir 使用upx壓縮
      r'--upx-dir','upx393w',\
      # --add-data 指定要包含的資源文件。
      # “C:\\Windows\\System32\\sciter.dll”為資源文件原本所在路徑(source)。
      # “.”為相對于exe文件的路徑(destination),在這里“.”為同一目錄的意思。
      # source路徑與destination路徑以英文狀態(tài)下分號“;”隔開。
      # r'--add-data', 'C:\\Windows\\System32\\sciter.dll;.', \
      # r'--add-data', 'D:\\work\\python\\my_editor\\helloworld\\pages\\word.html;pages'
      ]
  run(opts)

打包過程未報錯,但打包后執(zhí)行exe文件就出現(xiàn)問題了,如下圖,報錯“Failed to execute script helloworld”。

 Python3+PyInstall+Sciter中報錯缺少dll、html等文件怎么辦

就這么一句話,沒有其他任何的報錯信息,很令人惱火。后來查了資料,發(fā)現(xiàn)在打包時,可以指定exe以命令行模式執(zhí)行,就能看到報錯信息,而非以當前的窗口模式執(zhí)行。即將上述pack.py腳本中的opts選項列表里的“-w”改為“-c”。

再次打包執(zhí)行exe文件,發(fā)現(xiàn)了彈出了一個含有報錯信息的窗口。但是窗口一閃即逝,根本看不清里面的報錯信息。這是因為程序拋出異常退出了;即使不拋出異常,窗口也會因程序執(zhí)行完成而消失。于是將主程序helloworld.py的代碼改為如下:

#helloworld.py
import traceback
#加上try-except語句,是為了防止程序在出現(xiàn)異常時奔潰退出。
try:
  import sciter
except Exception as e:
  #打印異常棧軌跡。
  traceback.print_exc()
  #使程序阻塞,防止程序執(zhí)行完畢退出。
  a = input()

再次打包執(zhí)行exe文件,能看到報錯信息了,如下圖。其中的核心信息是“ImportError: C:\Windows\System32\sciter.dll was not found in PATH”,即缺少sciter.dll文件。

Python3+PyInstall+Sciter中報錯缺少dll、html等文件怎么辦

這就很奇怪了,在PyCharm中運行時沒報這個錯??!查看PyInstaller官網(wǎng),得知PyInstaller打包后的exe程序不能自動識別資源文件(如dll、html、png等文件)的路徑,需要在spec文件中指定datas選項。比如下面的helloworld.spec片段,添加了sciter.dll文件到與exe文件同級的目錄(.)中;添加了word.html到比exe文件所在目錄更深一層的目錄(pages)中(若是只報錯缺少dll文件,可不指定html文件)。

#helloworld.spec片段

a = Analysis(['D:\\work\\python\\my_editor\\helloworld\\helloworld.py'],
       pathex=['D:\\work\\python\\my_editor\\helloworld\\out'],
       binaries=[],
       datas=[('C:\\Windows\\System32\\sciter.dll', '.'), ('D:\\work\\python\\my_editor\\helloworld\\pages\\word.html', 'pages')],
       hiddenimports=[],
       hookspath=[],
       runtime_hooks=[],
       excludes=[],
       win_no_prefer_redirects=False,
       win_private_assemblies=False,
       cipher=block_cipher,
       noarchive=False)

但每次執(zhí)行完打包程序后,還要手動修改spec文件,很是麻煩。通過調(diào)試PyInstaller源代碼,找到了另一種方法,即在pack.py打包程序中的opts選項列表里加上兩個“--add-data選項”,如下:

#helloworld.py片段

opts = [
    """
    其他選項與上面的helloworld.py同,此處省略。
    """
    # --add-data 指定要包含的資源文件。
    # “C:\\Windows\\System32\\sciter.dll”為資源文件原本所在路徑(source)。
    # “.”為相對于exe文件的路徑(destination),在這里“.”為同一目錄的意思。
    # source路徑與destination路徑以英文狀態(tài)下分號“;”隔開。
    r'--add-data', 'C:\\Windows\\System32\\sciter.dll;.', \
    r'--add-data', 'D:\\work\\python\\my_editor\\helloworld\\pages\\word.html;pages'
    ]

再次打包運行exe文件,執(zhí)行成功!

2 要點總結

(1)調(diào)試打包時,指定PyInstaller打包程序參數(shù)為“-c”(命令行模式),方便閱讀報錯信息。等到調(diào)試完成正式上線后再改為“-w”。

(2)通過捕捉異常和使程序阻塞,防止程序過早退出,以便于看清楚報錯信息。

(3)PyInstaller打包后的exe程序不能自動識別資源文件(如dll、html、png等文件)的路徑,需要在spec文件中指定datas選項,或者在PyInstaller打包程序參數(shù)中指定一個或多個“--add-data”選項。

關于“Python3+PyInstall+Sciter中報錯缺少dll、html等文件怎么辦”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI