python3 强制使用任意父级相对导入,越过python相对导入限制,拒绝 ImportError

news/2025/2/10 22:34:32/

前言

  1. 单纯不喜欢 python 对 点开头的包的限制,好麻烦,遂写了本包,来解决这个问题
  2. 启用本模块后,你可以随时使用 单个点来导入当前目录的模块,也可以使用多个 点导入多级父目录内的模块,而不会报错烦人的模块相对路径限制错误。

解决

写了一个强制相对导入特性,修改了 import 的实现逻辑,从而允许导入任意父级的包,而不会报以下错误。
ImportError attempted relative import with no known parent package
ImportError attempted relative import beyond top-level package

修改import逻辑的方法来自这里
修改 python3 的 import 函数,从而实现挂钩hook或更改其行为
https://blog.csdn.net/ONE_SIX_MIX/article/details/128717665

仓库

github:https://github.com/One-sixth/force-relative-import

以下为搬过来的仓库介绍。

force-relative-import

这是一个强制启用python相对导入的库,允许你忽略python的相对导入限制。

安装

pip install -U force-relative-import

使用方法

目录示例,example_N 均为直接启动目标

├─example
│  │  example_1.py
│  │  example_2.py
│  │  example_3.py
│  │  moduleA.py
│  │
│  └─example_4
│      │  example_4.py
│      │
│      └─example_5
│              example_5.py

方法1 (推荐用于模块编写)

使用作用域,以避免意外情况。

example_1.py

from force_relative_import import enable_force_relative_importwith enable_force_relative_import():from .moduleA import return_goodprint(return_good())

example_4.py

from force_relative_import import enable_force_relative_importwith enable_force_relative_import():from ..moduleA import return_goodprint(return_good())

example_5.py

from force_relative_import import enable_force_relative_importwith enable_force_relative_import():from ...moduleA import return_goodprint(return_good())

方法2

使用函数。

example_2.py

from force_relative_import import enable_force_relative_import, global_enable_force_relative_import, global_disable_force_relative_importglobal_enable_force_relative_import()with enable_force_relative_import():from .moduleA import return_goodglobal_disable_force_relative_import()print(return_good())

方法3 (推荐仅用于主程序入口)

仅建议用于主程序,不要用于模块或包。

example_3.py

from force_relative_import import enable_nowfrom .moduleA import return_goodprint(return_good())

http://www.ppmy.cn/news/59044.html

相关文章

React Native中防止滑动过程中误触

React Native中防止滑动过程中误触 在使用React Native开发的时,当我们快速滑动应用的时候,可能会出现误触,导致我们会点击到页面中的某一些点击事件,误触导致页面元素响应从而进行其他操作,表现出非常不好的用户体验。 一、问题…

《程序员面试金典(第6版)》面试题 16.08. 整数的英语表示

题目描述 给定一个整数,打印该整数的英文描述。 示例 1: 输入: 123输出: “One Hundred Twenty Three” 示例 2: 输入: 12345输出: “Twelve Thousand Three Hundred Forty Five” 示例 3: 输入: 1234567输出: “One Million Two Hundred Thirty Four Thousand…

21安徽练习

题目分为4部分 APK 集群 流量 exe 我尽量都做一下,逆向不是很会,就当提升自己。 [填空题]请获取app安装包的SHA256校验值(格式:不区分大小写)(10分) e15095d49efdccb0ca9b2ee125e4d8136cac5…

前端三剑客React框架第一课入门的学习

前端三大框架React框架第一课入门的学习 前端三大框架的介绍 React:由facebook贡献,是一个基于javascript的前端库。它主要关注ui组件的构建,通过virtual dom等技术手段实现高效的渲染优化,可以与各种其他库和框架搭配使用,也有…

国产!全志科技T507-H工业核心板( 4核ARM Cortex-A5)规格书

1核心板简介 创龙科技 SOM-TLT507 是一款基于全志科技 T507-H 处理器设计的 4 核 ARM Cortex-A 53 全国产工业核心板,主频高达 1.416GHz 。核心板 CPU 、ROM 、RAM、电源、晶振等所有元器件均采用国产工业级方案,国产化率 100%。 核心板通过邮票孔连接方式引出 MIPI CSI 、…

SSL证书支持IP改成https地址

我们都知道SSL证书能为域名加密,那么IP地址可以实现https加密吗?答案当然是肯定的。为IP地址进行https加密不仅能保护IP服务器与客户端之间数据传输安全,还能对IP服务器进行身份验证,确保用户信息安全,增强用户对IP地址…

【文章学习系列之模型】Non-stationary Transformers

本章内容 文章概况总体结构主要模块Series Stationarization(序列平稳化模块)De-stationary Attention(逆平稳化注意力模块) 实验结果消融实验总结 文章概况 《Non-stationary Transformers:Exploring the Stationarity in Time …

Vue3.0

Vue3.0 动机与目的 更好的逻辑复用 与 代码组织 (composition组合式api) optionsAPI(旧) > compositionAPI(新), 效果: 代码组织更方便了, 逻辑复用更方便了 非常利于维护!! 更好的类型推导 (typescript支持) **vue3 源码用 ts 重写了, vue3 对 ts 的…