如何更改Python项目中的 模块搜索第一路径
内容承接上文:
Python语言中当前工作目录(Current Working Directory, cwd)与模块搜索第一路径都是指什么???
上文中已经解释了当前工作目录cwd与模块搜索路径的区别,本文讲一下模块搜索路径的修改方法。
-----------------------------------------------------
1. 修改sys.path中的路径
因为sys.path存的是模块搜索路径,可以直接对其进行修改,该种方式不好的地方就是会破坏项目代码的原有结构

yyy.py 文件内容:
print("Thist is yyy.py file.")
xxx.py 文件内容:
import sys
import os print("修改前,模块搜索路径:")
print(sys.path) r_path = ".."+os.sep+".." # python中相对路径的根路径为当前工作目录
sys.path[0] = os.path.realpath(sys.path[0]+os.sep+r_path)
# print(sys.path[0]) print("修改后,模块搜索路径:")
print(sys.path) import yyy0
import yyy0.yyy1.yyy
运行结果:

可以看到通过修改sys.path可以实现模块搜索路径的修改。
=================================================
2. 创建.pth 文件
在python的模块搜索路径site-packages下创建以.pth为后缀的文件,并在.pth文件中写入你想要加入的模块搜索路径。该种方法只能添加模块搜索路径并不能更改,同时你需要找到site-packages路径然后在其中创建文件,步骤要繁琐一些,好处是不会破坏原始代码结构,该种方式可以作为调试项目子模块的方法来使用。
如何寻找site-packages路径呢,我们可以使用python3 -m site的命令来查找。
在Ubuntu22.04系统下原生python下寻找site-packages路径:

在Ubuntu22.04系统下aconda下寻找site-packages路径:

这里我们创建my.pth文件,内容如下:
/home/devil/12345

xxx.py文件内容修改如下:
import sys
import os print("当前,模块搜索路径:")
print(sys.path) import yyy0
import yyy0.yyy1.yyy

可以看到添加的路径排在了site-packages路径后面。
使用该种方式可以不破坏原有代码结构对子模块代码进行单独测试,对于项目开发来说还是很好用的,不足的地方就是配置起来比较繁琐一些。该种方法添加搜索路径后会一直生效,如果要清除该添加路径则需要重新修改.pth文件。
=======================================================
3. 设置PYTHONPATH环境变量
作为环境变量,我们可以在终端命令中设置PYTHONPATH环境变量也可以在vscode中通过env变量的方式设置该变量。注意该种方法必须在python启动之前设置该环境变量,如果启动后通过os.environ["PYTHONPATH"] 的方式设置该环境变量是无效的,是不会将该路径添加到模块搜索路径中的,原理就是python在启动的时候会查找是否有PYTHONPATH变量,如果有则将其加入到模块搜索路径中。
此时修改xxx.py文件内容如下:
import sys
import os print("当前,模块搜索路径:")
print(sys.path) import yyy0
import yyy0.yyy1.yyy
执行结果:

可以看到通过设置PYTHONPATH环境变量成功添加模块搜索路径,该路径排在第一路径之后。
使用该方法比较灵活,由于在终端中设置的环境变量其生命周期只在当前终端内因此也可以避免污染其他项目。而且如果我们使用vscode这样的编译器的化可以在launch.json文件进行较为方便的设置的。
给出自己定义的vscode下的launch.json文件内容:
{
// 使用 IntelliSense 了解相关属性。
// 悬停以查看现有属性的描述。
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "Python: Current File",
"type": "python",
"request": "launch",
"program": "${file}",
"console": "integratedTerminal",
"justMyCode": true,
"env": {"PYTHONPATH":"${workspaceFolder}"}
}
]
}
不使用vscode的项目配置执行xxx.py文件:

发现报错,然后通过vscode的环境配置来执行,按键F5:

可以看到在vscode中通过配置launch.json中环境变量PYTHONPATH可以方便的启动子模块内的代码并且保持模块搜索路径依旧具有顶层模块的路径。
====================================
4. python3 -m 的模块启动方式
该种方式是在启动时根据启动命令确定模块搜索路径。熟悉Java的同学可以回想下Java中执行包内代码时的启动方式,和这个python中的模块启动方式比较像。
文件夹结构不变,xxx.py文件内容:
import sys
import os print("当前,工作目录:")
print(os.getcwd())
print("当前,模块搜索路径:")
print(sys.path) import yyy0
import yyy0.yyy1.yyy
当前在'/home/devil/12345'目录下,执行命令为:
python3 -m xxx0.xxx1.xxx
结果:

当前在'/home/devil/12345/xxx0'目录下,执行命令为:
python3 -m xxx1.xxx

可以看到通过模块启动的方式启动python代码时其当前工作目录即为其模块搜索的第一路径。
该种方式使用起来最为简单,不过该种方法不能通过IDE的方式来启动,因此如果比较依赖可视化界面编程的同学就不能通过该种启动方式来设置模块搜索路径了,但是该种方式作为临时之用还是不错的,毕竟不用什么其他的设置即可运行。
===================================
相关内容:
[python]自问自答:python -m参数? ( python3.7 版本 )
如何更改Python项目中的 模块搜索第一路径的更多相关文章
- Python项目中如何优雅的import
Python项目中如何优雅的import 前言 之前有一篇关于Python编码规范的随笔, 但是写的比较杂乱, 因为提到了import语句, 在篇文章中, 我专门来讲Python项目中如何更好的imp ...
- 在 python 项目中如何记录日志
一. 概述 写本文的目的是我在写 python 项目的时候需要记录日志,我忘记怎么处理了,每次都需要去网上查一遍,好记性不如烂笔头, 这里把查阅的内容记录下来,方便以后查找. python 项目中记录 ...
- python项目中requirements的巧用(一键导入所有安装包)
一个Python 项目中可能安装很多安装包, 再次创建虚拟环境是需要重新安装的话很麻烦也费时间, 或者项目部署的时候避免重装, 可以将现有项目的所有安装包记录在requirements.txt 文件, ...
- Maven 项目中依赖的搜索顺序
Maven 项目中依赖的搜索顺序 http://www.manongjc.com/article/13422.html 执行过程中使用 -e -X 查看详细的搜索地址: 1,中央仓库,这是默认的仓库 ...
- python 项目中包中__init__.py文件的作用
开发python项目时,我遇到了一个这样的现象,当我新建一个pythonpackage时,总会自动地生成一个空的__init__.py文件,因为是python新手,所以很不了解这个空文件的作用是什么, ...
- Python项目中的单元测试
引入 单元测试负责对最小的软件设计单元(模块)进行验证,unittest是Python自带的单元测试框架. 单元测试与功能测试都是日常开发中必不可少的部分,本文演示了Python中unittest单元 ...
- [git]安装git-pylint-commit-hook提高python项目中的代码质量
什么是'git-pylint-commit-hook' 我在工作中,团队为了保证代码和提高代码的质量,要求每个项目都要求安装git-pylint-commit-hook,它是个钩子,会在你提交代码到本 ...
- 生成指定python项目中所有的依赖文件
一. pipreqs工具 这个工具的好处是可以通过对项目目录的扫描,自动发现使用了那些类库,自动生成依赖清单. 缺点是可能会有些偏差,需要检查并自己调整下. 安装: pip install pipre ...
- 由web项目中上传图片所引出的路径问题
我在做javaweb项目的时候,有个项目中需要进行图片的上传,有次我重新部署项目后,发现之前上传的图片不见了,最后找出原因:图片上传在服务器目录上,而不是绝对路径,所以特别想弄清楚javaweb项目中 ...
- IDEA的maven项目中静态文件编译的路径问题(未测试)
转自:http://www.cnblogs.com/signheart/p/6625126.html IDEA的maven项目中,默认源代码目录下的xml等资源文件并不会在编译的时候一块打包进clas ...
随机推荐
- C++面向对象语言自制多级菜单
因为要做一个小应用,需要一个菜单类,在网上找了许久,也没有找到一款心仪的菜单类,索性用C++语言,自制一个命令行级别的菜单类,并制作成库,现记录下来,供以后借鉴. 一.特性 无限制条目 无限制层级 用 ...
- 各种语言的OEP大全
Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` 各种语言的OEP大全 日期:2017-5-19 阿珏 教程 ...
- Isolution
<template> <div style="float:left;width: 100%; margin-left: 0"> <el-row > ...
- spring与设计模式之三代理模式
部分内容引用: https://blog.csdn.net/shulianghan/article/details/119798155 一.定义 1.1定义 对于现实生活中的代理,大家非常好理解.我们 ...
- Linux 内核:I2C子系统分析(1)基于子系统的驱动分析与实现
Linux 内核:I2C子系统分析(1)基于子系统的驱动分析与实现 背景 在学习高通平台的有关知识,看到一篇博客中介绍了GPIO模拟I2C设备,觉得挺有意思的. 看了看有关的实现,发现自己之前学习从L ...
- Android Camx 架构介绍
Android Camx 架构介绍 原文链接:深入理解高通Camx Hal 概览 高通平台的Camera架构从以前用的mm-camera转向camx-chi,完全是两样不同的东西:软件架构不同.代码位 ...
- 【Mysql】Mysql字符集CHARACTER和COLLATE
一:设置服务器默认字符集为 utf8mb4 创建数据库时,如果没有指定字符集,会采用服务器的默认字符集.设置服务器默认字符集为 utf8mb4 可以提高便利性. 编辑 MySQL 的配置文件,修改服务 ...
- yb课堂之实战登陆模块开发整合Json Web Token《十》
开发登陆模块功能,并整合Json Web Token 开发登陆功能 LoginRequest.java UserMapper.xml UserMapper.java UserService.java ...
- 分布式事务的概念和解决方案Seate
引入分布式事务: 在电商系统中,扣减库存与保存订单是在两个服务中存在的,如果扣减库存后订单保存失败了是不会回滚的,这样就会造成数据不一致的情况,这其实就是我们所说的分布式事务的问题,接下来我们来学习分 ...
- 解决方案 | onenote无法同步,显示:证书错误,应用程序在加载SSL库是遇到内部错误。
解决方案:一般是公司网络或者学校网络的问题,更换手机使用的数据流量热点无线网络即可.