1.问题
ubuntu18.04自带了python2.7,工作需要安装了其他版本的python(anaconda,python3.5)。使用中,遇到输入python ****.py时可以正常运行,但是sudo python ***.py时出现包导入错误:ImportError: No module named xxx
2.分析
(1)由于python import的模块路径存在与sys.path中,在脚本中报ImportError之前,加入打印:
import sys
print(sys.path)
输入 sudo python ***.py:
['/home/yhb/share', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-x86_64-linux-gnu', ......]
输入 python ***.py:
['/home/yhb/share', '/home/yhb/detvm/python', ......, '/home/yhb/anaconda3/lib/python35.zip', '/home/yhb/anaconda3/lib/python3.5',......]
(2)在terminal直接输入sudo python和python,会发现python的版本确实是不一样的:
输入sudo python时:
输入python时:
解决方案
-
(1)解决2(1)中的导入顺序问题
虽然anaconda安装完成后,在~/.bashrc中也设置了 PYTHONPATH和PATH的环境变量,为什么还会在sudo python test.py时出现包导入错误,而在使用python test.py时又是正常的呢?这是因为在使用sudo模式执行程序的时候,系统会自动重置PATH环境变量。
-
(2)解决2(2)中python版本使用问题,可以用重建到anaconda版本python的软连接方式解决:
sudo cp /usr/bin/python /usr/bin/python_bak sudo rm /usr/bin/python sudo ln -s /home/yhb/anaconda3/bin/python3.5 /usr/bin/python
修改完成后再输入sudo python可以看到当前使用的是anaconda中的python3.5