python 指定源路径来解决import问题的操作


Posted in Python onMarch 04, 2021

用python做大型工程时,经常会出现import问题。比如,当你import另一个py文件时,这个py不存在于你的运行路径下,便会报错。

大概有两种方法:

如果在terminal里,咱们可以通过sys.path.append来添加运行路径;如果在pycharm环境里,咱们可以右键Mark Directory as Sources Root。

举个栗子:vim head.py

def add(a, b):
 return a + b

vim run.py

import head
a = 3
b = 4
c = head.add(a, b)
print(c)

咱们把head.py和run.py放在一个路径下,文件结构如下:

my_path
├── head.py
└── run.py

咱们运行run.py:

cd my_path
python run.py

直接成功运行没有毛病。但是,如果路径关系再复杂点呢?比如

my_path
├── folder_a
│ └── run.py
└── folder_b
└── head.py

如果cd my_path/folder_a,然后python run.py。肯定会报路径错误。这个时候,如果你是用pycharm开发这个工程,你可以直接

python 指定源路径来解决import问题的操作

倒数第三行,mark directory as source root。直接把folder_b设置为一个源根目录,这样folder_b下的文件都可以直接不加前缀地被import。

如果你是在terminal运行,没办法像pycharm那么设计,或者需要从pycharm部署到terminal时,你可以用sys.path.append()来添加源路径。

咱们只需要添加两句:

import sys
sys.path.append('../folder_b')
import head
a = 3
b = 4
c = head.add(a, b)
print(c)

只需要开头加两行就可以完成源路径的指定,源路径下的所有py都可以被不加前缀直接import。你学废了吗

补充:Python国内镜像源路径和设置方法

最近学习Python需要安装第三方的库,基本是国外网站,安装缓慢,于是找到了解决方法,记录下来:使用Python国内镜像源路径,可以快速安装。

国内源路径汇总:

清华:https://pypi.tuna.tsinghua.edu.cn/simple

阿里云:http://mirrors.aliyun.com/pypi/simple/

中国科技大学 https://pypi.mirrors.ustc.edu.cn/simple/

华中理工大学:http://pypi.hustunique.com/

山东理工大学:http://pypi.sdutlinux.org/

豆瓣:http://pypi.douban.com/simple/

使用案例:

例如:pip3 install -i https://pypi.doubanio.com/simple/ 包名

临时使用方式:

可以在使用pip的时候加参数-i https://pypi.tuna.tsinghua.edu.cn/simple

例如:pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pyqt5,这样就会从清华这边的镜像去安装pyqt5库。

永久修改使用方式:

Linux下,修改 ~/.pip/pip.conf (没有就创建一个文件夹及文件。文件夹要加“.”,表示是隐藏文件夹)

内容如下:

[global]
index-url = https://pypi.tuna.tsinghua.edu.cn/simple
[install]
trusted-host=mirrors.aliyun.com

windows下,直接在user目录中创建一个pip目录,再新建文件pip.ini。(例如:C:\Users\WQP\pip\pip.ini)内容同上。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。如有错误或未考虑完全的地方,望不吝赐教。

Python 相关文章推荐
Windows下使Python2.x版本的解释器与3.x共存的方法
Oct 25 Python
Python自动化测试Eclipse+Pydev 搭建开发环境
Aug 15 Python
Python绑定方法与非绑定方法详解
Aug 18 Python
pandas 实现将重复表格去重,并重新转换为表格的方法
Apr 18 Python
python爬取微信公众号文章
Aug 31 Python
python+selenium实现QQ邮箱自动发送功能
Jan 23 Python
详解Python_shutil模块
Mar 15 Python
python基于paramiko将文件上传到服务器代码实现
Jul 08 Python
如何使用python操作vmware
Jul 27 Python
django为Form生成的label标签添加class方式
May 20 Python
Python+Selenium实现自动化的环境搭建的步骤(图文)
Sep 01 Python
属性与 @property 方法让你的python更高效
Sep 21 Python
python源文件的字符编码知识点详解
Mar 04 #Python
python3判断IP地址的方法
Mar 04 #Python
Python解析m3u8拼接下载mp4视频文件的示例代码
Mar 03 #Python
python和opencv构建运动检测器的实现
Mar 03 #Python
Python3自带工具2to3.py 转换 Python2.x 代码到Python3的操作
Mar 03 #Python
详解python第三方库的安装、PyInstaller库、random库
Mar 03 #Python
聊聊Python pandas 中loc函数的使用,及跟iloc的区别说明
Mar 03 #Python
You might like
php 变量定义方法
2009/06/14 PHP
php object转数组示例
2014/01/15 PHP
php实现批量修改文件名称的方法
2016/07/23 PHP
PHP让数组中有相同值的组成新的数组实例
2017/12/31 PHP
很可爱的输入框
2008/08/03 Javascript
javascript json 新手入门文档
2009/12/03 Javascript
javascript实现表单提交后,提交按钮不可用的方法
2015/04/18 Javascript
纯javascript移动优先的幻灯片效果
2015/11/02 Javascript
基于jQuery Tipso插件实现消息提示框特效
2016/03/16 Javascript
JS实现图文并茂的tab选项卡效果示例【附demo源码下载】
2016/09/21 Javascript
vue3.0 CLI - 2.1 -  component 组件入门教程
2018/09/14 Javascript
vue实现前台列表数据过滤搜索、分页效果
2019/05/28 Javascript
小程序怎样让wx.navigateBack更好用的方法实现
2019/11/01 Javascript
JavaScript算法学习之冒泡排序和选择排序
2019/11/02 Javascript
深度解读vue-resize的具体用法
2020/07/08 Javascript
vue 项目软键盘回车触发搜索事件
2020/09/09 Javascript
vue-cli3项目打包后自动化部署到服务器的方法
2020/09/16 Javascript
vue中使用echarts的示例
2021/01/03 Vue.js
[01:31](回顾)杀出重围,决战TI之巅
2014/07/01 DOTA
在Django框架中设置语言偏好的教程
2015/07/27 Python
python生成器,可迭代对象,迭代器区别和联系
2018/02/04 Python
儿童python练习实例
2018/05/27 Python
Python生成短uuid的方法实例详解
2018/05/29 Python
Python OS模块实例详解
2019/04/15 Python
Django学习笔记之为Model添加Action
2019/04/30 Python
Python hexstring-list-str之间的转换方法
2019/06/12 Python
python tkinter之顶层菜单、弹出菜单实例
2020/03/04 Python
详解Python3 定义一个跨越多行的字符串的多种方法
2020/09/06 Python
HTML5和CSS3让网页设计提升到下一个高度
2009/08/14 HTML / CSS
adidas马来西亚官网:adidas MY
2020/09/12 全球购物
介绍一下mysql的日期和时间函数
2013/03/28 面试题
高一政治教学反思
2014/01/28 职场文书
致百米运动员广播稿
2014/01/29 职场文书
运动会稿件100字
2014/09/24 职场文书
党的群众路线教育实践活动实施方案
2014/10/31 职场文书
vue前端工程的搭建
2021/03/31 Vue.js