引言:在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 Widgetstkinter3000 (1.1-20051211) - Widget Construction Kit for Tkintertkinterhtml (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.......................

于是尝试直接安装tkinter,结果没有发现tkinter包

> pip3 install tkinterCollecting tkinterCould not find a version that satisfies the requirement tkinter (from versions: )No matching distribution found for tkinter

什么是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 library

上述是已经安装的显示信息,如果没有安装,则需要执行,安装指令:

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

提示可以正确加载。于是重新执行了之前的原程序,可以正确输出结果了。问题到此为止,已经被正确的解决。

过程总结分析

这里讲其中的得失点进行一下总结:

  1. tkinter是一个python的接口类库,用以调用tcl/tk程序,故一般在操作系统层面会有相应的类库安装,而非仅仅依靠pip3来安装相应的python类库,比如, python3-tk

  2. devel库的安装,在*unix系统中,在进行开发之中,很多情况下是需要devel类库安装的,这个是一个大概率的规则。

  3. 某些情况下,会出现安装不完整的情况或者安装缺失某些类库的情况。这个时候可以考虑重新覆盖安装,比如tcl/tk, python3的重新安装

  4. 重视错误信息的分析和方向性指引。 在本案例中,关键的提示信息有2个部分,其一,moulde未安装或没有找到,则从安装类库的方向进行尝试解决。 其二, 假定包已经安装,但是未被正确的配置好。 笔者在解决问题之时,首选了思路一来进行解决;在碰到各种尝试失败之后,才不得不转向其二的思路来解决。如果从两个方向同时来解决的话,或者这个问题可以被更快的解决。

笔者解决这个问题花费了大约3~4个小时左右。

Python下No module named _tkinter问题解决过程总结相关推荐

  1. 给python安装tkinter模块(及各种问题的解决:如 ModuleNotFoundError: No module named ‘_tkinter’)

    文章目录 前言 1. 环境 2. 问题描述 3. 给Python2.7安装tkinter 4. 给python3.6.3安装tkinter(注意:这里失败了,但是过程值得记录一下) 5. [可行方案] ...

  2. install python-tk_No module named _tkinter, please install the python-tk package 解决方法总结

    0. 前言 在ipython环境中,要用到matlotlib库,运行.py文件时,提示以下错误: No module named _tkinter, please install the python ...

  3. Python ImportError: No module named Image

    /********************************************************************************** Python ImportErr ...

  4. python ImportError: No module named unittest2

    2019独角兽企业重金招聘Python工程师标准>>> python ImportError: No module named unittest2 下载地址:https://pypi ...

  5. python ModuleNotFoundError: No module named ‘requests‘ 的 解决方案

    python ModuleNotFoundError: No module named 'requests' 的 解决方案 参考文章: (1)python ModuleNotFoundError: N ...

  6. VSCode Python解决 No module named 问题

    见:VSCode Python解决 No module named 问题_努力中的老周的专栏-CSDN博客

  7. python.exe: No module named pip以及pycharm下载插件失败等问题

    只要把pip升级一下就行了 如果你在dos里输入 python -m pip install --upgrade pip 报python.exe: No module named pip这个错误 你可 ...

  8. Python 技术篇-httpClient库连接服务器发送请求解析响应实例演示,No module named ‘httplib‘问题解决方法

    新的 python 已经由 httplib 包变成了 http.client. 所以如果还引入 httplib 库就会报错:ModuleNotFoundError: No module named ' ...

  9. Python双版本下No module named 'requests'

    注意:如果电脑有python2和python3 共存的情况需要pip指定安装路径,系统一般自带了python2.7,pip会默认安装在python2的版本上.所以你在使用python3的时候依然提示N ...

最新文章

  1. 人工智能 有信息搜索 (启发式)
  2. unix系统编程小结(二)------文件和目录
  3. control.add()
  4. linux c 遍历目录 及 目录下文件
  5. 2020年8月编程语言排行榜新鲜出炉 - 编程语言世界的假期
  6. Mysql_mysql 性能分析及explain用法
  7. mysql主从同步slave_MySQL主从复制(Master-Slave)实践
  8. Ssm手机电脑自适应新闻博客系统实战开发
  9. Startlsback常见使用过程中的问题
  10. 多线程调用同一个对象的方法_这一次,让我们完全掌握Java多线程(2/10)
  11. CodeForces - 1013B And 与运算暴力
  12. 九种跨域方式的实现原理,第一个就超惊艳!| 技术头条
  13. 生活杂谈-空调的修理
  14. springboot静态集成redis客户端
  15. 操作系统启动后 计算机处于 模式,电脑开机出现选择操作系统。怎么办?
  16. 【Matlab读取图片提取RGB分量并将图片转化为二维三维数据作图】
  17. 合宙Luat | 嘿~合宙刚办了一场「大型网友见面会」
  18. 外汇EA自动交易的利与弊
  19. 我推荐这几个好玩有趣的小网站
  20. 4/2 三元表达式/函数递归/匿名函数/内置函数

热门文章

  1. Tim实现截图的方法
  2. MATLAB笔记4:特殊矩阵 zeros、ones、eye、rand、randn;magic、vander、hilb、pascal
  3. 旅行社管理系统 java_旅行社管理系统纯Java
  4. 测试驱动开发-TDD
  5. luogu P3396 哈希冲突 根号算法
  6. 什么是工控主板?工控主板和商业主板的区别有哪些?
  7. 苹果Foundation框架视频课程-关东升-专题视频课程
  8. afudos备份bios不动_afudos怎么备分bios
  9. MATLAB/Simulink永磁直驱风力发电系统仿真模型 本模型针对定桨距角的永磁直驱风机系统,包含风力机传动部分,整流器控制部分,逆变器控制部分,mppt(爬山搜索法)四大部分
  10. 计算机配置及性能测试,配置性能测试及总结_一体电脑评测-中关村在线