2021-05-12 14:32:11
Python下「No module named _tkinter」問題解決過程總結
引言:在Python3下執行Matplotlib之時,碰到了”No module named _tkinter“的問題,花費數小時進行研究解決,這裡講整個過程記錄下來,並嘗試分析過程中的解決思路利弊得失,以資後效,這裡重點提示需要關注錯誤資訊的分析,這個是第一現場。
環境介紹
任何技術問題的出現以及修復都是依賴於系統環境以及特定版本的,這裡首先描述如下:
Ubuntu: 17.10
Python: 3.6.1 基於virutalenv來切換不同的Python環境
tkinter的問題描述
原程式中基於matplotlib來進行繪圖操作,其中在執行過程中,報出來了錯誤資訊。由於原程式大部分無關問題本身,且紀錄檔本身比較多,這裡僅僅擷取關鍵資訊:
import _tkinter # If this fails your Python may not be configured for Tk
ImportError: No module named _tkinter
問題初步分析
用過python的朋友都知道,碰到類似的問題,比如import Error,大概率情況下都是某個包未安裝,故第一反應就是某個包缺失了,於是首先進行了包和類庫的查詢:
pip3 search tkinter
結果發現大量的包,被匹配到,其中若干相關的包有tkinter,這些資訊基本上沒有幫助。
..................
tkinter.help (2.0) - Small Preview of Tkinter Widgets
tkinter3000 (1.1-20051211) - Widget Construction Kit for Tkinter
tkinterhtml (0.7) - Python wrapper for Tkhtml3 (http://tkhtml.tcl.tk/)
tkinterquickhelper (1.5.18) - Helpers for tkinter, extra windows.
tkintertable (1.2) - Extendable table class for Tkinter
.......................12345678910111213
於是嘗試直接安裝tkinter,結果沒有發現tkinter包
> pip3 install tkinter
Collecting tkinter
Could not find a version that satisfies the requirement tkinter (from versions: )
No matching distribution found for tkinter1234567
什麼是tkinter, tcl ,tk
The tkinter package (“Tk interface”) is the standard Python interface to the Tk GUI toolkit. Both Tk and tkinter are available on most Unix platforms, as well as on Windows systems. (Tk itself is not part of Python; it is maintained at ActiveState.) You can check that tkinter is properly installed on your system by running python -m tkinter from the command line; this should open a window demonstrating a simple Tk interface.
上述檔案摘自Python社群:https://docs.python.org/3/library/tkinter.html
tkinter其實是Python呼叫tcl程式的標準Python程式,可以通過這個interface呼叫tcl的程式,因為在大多數的unix系統中都內建了很多的tcl程式和命令。
Tcl 是“工具控制語言(Tool Command Language)”的縮寫,其物件導向為otcl語言。Tk 是 Tcl“圖形工具箱”的擴充套件,它提供各種標準的 GUI 介面項,以利於迅速進行高階應用程式開發。
於是,執行terminal 命令:
python -m tkinter
如果執行正確的話,可以看到如下介面指令,這裡主要是指在Linux的桌面系統下:
嘗試解決問題-1
在網路上初次搜尋之後,發現有人提示說python-tk/python3-tk的類庫需要在作業系統層面進行安裝。本次案例以Ubuntu為例, 查詢其是否安裝:
>sudo apt search python3-tk
正在排序... 完成
全文搜尋... 完成
python3-tk/artful,now 3.6.3-0ubuntu1 amd64 [已安裝]
Tkinter - Writing Tk applications with Python 3.x
python3-tk-dbg/artful 3.6.3-0ubuntu1 amd64
Tkinter - Writing Tk applications with Python 3.x (debug extension)
python3-tksnack/artful,artful,now 2.2.10.20090623-dfsg-6 all [已安裝]
Sound extension to Tcl/Tk and Python/Tkinter - Python 3.x library123456789
上述是已經安裝的顯示資訊,如果沒有安裝,則需要執行,安裝指令:
sudo apt install python3-tk (Ubuntu)
yum install python3-tk (CentOS)
在安裝完成之後,重新執行程式,然後報出同樣的錯誤,問題仍然存在。
然後有發現有資訊說,需要安裝tk的開發類庫,於是,在查詢之後未安裝之後,直接進行安裝:
sudo apt install tk-dev (Ubuntu/Debian)
yum install tk-devel (CentOS)
在安裝之後,重新執行程式,錯誤仍然存在。
嘗試解決問題-2
在stackoverflow上搜尋一番之後,發現有人提示說,某些情況下是tcl/tk安裝不完整造成的,於是就重新下來了tcl/tk的原始碼包:
下載連結: http://www.tcl.tk/software/tcltk/download.html
然後分別下來兩者原始碼,加壓縮之後,切入原始碼目錄:
configure
make or make test
sudo make install
在重新安裝tck/tk之後,重新執行程式碼,問題依然存在。
最終解決問題
在嘗試了若干次之後,自我感覺該安裝和設定的選項都做了,怎麼問題依然存在呢?我忽然發覺提示錯誤資訊中的第一句關鍵資訊:
If this fails your Python may not be configured for Tk
或許這裡的問題,根本不是tkinter沒有安裝,或者被正確安裝完成,而是沒有被正確的設定好。目前tcl/tk的內容都已經安裝好了,只是在python中沒有設定好,但是python3-tk之類的都已經安裝了,但是問題並沒有被解決。如果這樣,那就重新安裝Python執行環境吧。
由於目前的*unix系統都是基於python 2.x系列的,如果需要使用Python3則需要自行進行程式碼的編譯安裝,於是重新基於原始碼進行了編譯和安裝, 然後進入python的命令列,
import tkinter
提示可以正確載入。於是重新執行了之前的原程式,可以正確輸出結果了。問題到此為止,已經被正確的解決。
過程總結分析
這裡講其中的得失點進行一下總結:
tkinter是一個python的介面類庫,用以呼叫tcl/tk程式,故一般在作業系統層面會有相應的類庫安裝,而非僅僅依靠pip3來安裝相應的python類庫,比如, python3-tk
devel庫的安裝,在*unix系統中,在進行開發之中,很多情況下是需要devel類庫安裝的,這個是一個大概率的規則。
某些情況下,會出現安裝不完整的情況或者安裝缺失某些類庫的情況。這個時候可以考慮重新覆蓋安裝,比如tcl/tk, python3的重新安裝
重視錯誤資訊的分析和方向性指引。 在本案例中,關鍵的提示資訊有2個部分,其一,moulde未安裝或沒有找到,則從安裝類庫的方向進行嘗試解決。 其二, 假定包已經安裝,但是未被正確的設定好。 筆者在解決問題之時,首選了思路一來進行解決;在碰到各種嘗試失敗之後,才不得不轉向其二的思路來解決。如果從兩個方向同時來解決的話,或者這個問題可以被更快的解決。
筆者解決這個問題花費了大約3~4個小時左右。
相關文章