当文件名包含句点时如何引用python包

发布于 2024-08-13 06:50:36 字数 291 浏览 6 评论 0 原文

我正在使用 django,并且有一个名为 models.admin.py 的文件,我想在 models.py 中执行以下操作:

from "models.admin" import *

但是,由于使用双引号,我收到语法错误。但如果我这样做

from models.admin import *

,就会得到“ImportError:没有名为 admin 的模块”

有没有办法从名称中包含句点的 python 文件导入?

I am using django and I have a file named models.admin.py and I want to do the following idea in models.py:

from "models.admin" import *

however, I get a syntax error for having double quotes. But if I just do

from models.admin import *

then I get "ImportError: No module named admin"

Is there any way to import from a python file that has a period in its name?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(7

╭⌒浅淡时光〆 2024-08-20 06:50:36

实际上,您可以导入具有无效名称的模块。但是您需要使用 imp ,例如假设文件名为 models.admin.py,您可以这样做

import imp
with open('models.admin.py', 'rb') as fp:
    models_admin = imp.load_module(
        'models_admin', fp, 'models.admin.py',
        ('.py', 'rb', imp.PY_SOURCE)
    )

但是请阅读 imp.find_moduleimp.load_module 在开始使用之前。

Actually, you can import a module with an invalid name. But you'll need to use imp for that, e.g. assuming file is named models.admin.py, you could do

import imp
with open('models.admin.py', 'rb') as fp:
    models_admin = imp.load_module(
        'models_admin', fp, 'models.admin.py',
        ('.py', 'rb', imp.PY_SOURCE)
    )

But read the docs on imp.find_module and imp.load_module before you start using it.

那请放手 2024-08-20 06:50:36

如果您确实想要,您可以使用 imp 模块导入具有不寻常文件名的模块(例如,在“.py”之前包含“.”的文件名):

>>> import imp
>>> a_b = imp.load_source('a.b', 'a.b.py')
>>> a_b.x
"I was defined in a.b.py!"

但是,这通常是一个不好的方法主意。您更有可能尝试使用包,在这种情况下,您应该创建一个名为“a”的目录,其中包含一个名为“b.py”的文件;然后“import ab”将加载a/b.py。

If you really want to, you can import a module with an unusual filename (e.g., a filename containing a '.' before the '.py') using the imp module:

>>> import imp
>>> a_b = imp.load_source('a.b', 'a.b.py')
>>> a_b.x
"I was defined in a.b.py!"

However, that's generally a bad idea. It's more likely that you're trying to use packages, in which case you should create a directory named "a", containing a file named "b.py"; and then "import a.b" will load a/b.py.

我家小可爱 2024-08-20 06:50:36

该文件名为 models/admin.py。 (来源

也就是说,它应该在名为 models 的目录中名为 admin.py

然后,您可以使用 from models.admin import * 进行导入,假设它位于您的 Python 路径中。

The file is called models/admin.py. (Source)

That is, it should be called admin.py in a directory called models.

Then you can import using from models.admin import *, assuming that it is in your Python path.

最初的梦 2024-08-20 06:50:36

如下

假设 dir 结构如下:

C:.
│   script.py
│   
└───Parent
    └───Child
        ├───1.1
        │       main.py
        │       
        └───1.2

**假设您要在 script.py 中导入 main.py **

您的 main.py 如下所示

def my_function():
  print("Hello from a function")

您的 script.py 如下所示< /strong>

from os import path
import importlib
from os.path import dirname
import sys
import importlib.util


def getPath():
    # your logic to get to the path
    return path.join(dirname(__file__),'Parent','Child','1.1','main.py')

file_path = getPath() 
module_name = 'main'

spec = importlib.util.spec_from_file_location(module_name, file_path)
module = importlib.util.module_from_spec(spec)
spec.loader.exec_module(module)

#call functions like this
module.my_function()

查看此要点

Like below

Assume dir structure is like this:

C:.
│   script.py
│   
└───Parent
    └───Child
        ├───1.1
        │       main.py
        │       
        └───1.2

**assume you want to import main.py in script.py **

your main.py looks like below

def my_function():
  print("Hello from a function")

your script.py looks like below

from os import path
import importlib
from os.path import dirname
import sys
import importlib.util


def getPath():
    # your logic to get to the path
    return path.join(dirname(__file__),'Parent','Child','1.1','main.py')

file_path = getPath() 
module_name = 'main'

spec = importlib.util.spec_from_file_location(module_name, file_path)
module = importlib.util.module_from_spec(spec)
spec.loader.exec_module(module)

#call functions like this
module.my_function()

Check out this gist

温折酒 2024-08-20 06:50:36

不,如果 python 文件的名称包含句点(或问号、感叹号等),则无法将其作为模块导入。 python 模块的名称(不包括 .py)必须是有效的 python 名称(即可以用作变量名称)。

No, you can't import a python file as a module if its name contains a period (or a question mark, or exclamation mark, etc). A python module's name (not including the .py) must be a valid python name (ie can be used as a variable name).

请你别敷衍 2024-08-20 06:50:36

就我而言,我使用的是grafanalib,文件名必须是xx.dashboard.py,基于doc。但是,我确实想导入此文件以简化上传步骤。

当我使用 import imp 时收到警告:

imp 模块已被弃用,取而代之的是 importlib,并计划在 Python 3.12 中删除;请参阅模块的文档以了解其他用途

这是使用 importlibpathlib 的简单演示:

foo.bar.pymain.py 位于同一个文件夹中。

# foo.bar.py

num = 42
# main.py

import importlib.machinery
import pathlib

module = importlib.machinery.SourceFileLoader(
    "foo_bar",
    pathlib.Path(__file__).parent.joinpath("foo.bar.py").resolve().as_posix(),
).load_module()
print(module.num)  # 42

In my case, I am using grafanalib, and the filename has to be xx.dashboard.py based on the doc. However, I do want to import this file to simplify the uploading step.

I got warning when I use import imp:

the imp module is deprecated in favour of importlib and slated for removal in Python 3.12; see the module's documentation for alternative uses

Here is the simple demo using importlib and pathlib:

foo.bar.py and main.py are in the same foler.

# foo.bar.py

num = 42
# main.py

import importlib.machinery
import pathlib

module = importlib.machinery.SourceFileLoader(
    "foo_bar",
    pathlib.Path(__file__).parent.joinpath("foo.bar.py").resolve().as_posix(),
).load_module()
print(module.num)  # 42
无远思近则忧 2024-08-20 06:50:36

您在导入语句中引用的不是文件,而是模块

请阅读 docs,他们对此非常清楚。

无论如何,由于你使用的是 django,通常的方法是行不通的。如果您想将模型保存在单独的文件中,而不是在 models.py 中,则必须采取额外的步骤,例如,此处

编辑:
嗯,我实在不知道提问者提到admin是什么意思,是否与django的admin界面有关。我的观点仍然成立。

You are not referencing files in the import statement, you are referencing modules and packages.

Please read the docs, they are very clear on that matter.

Anyway, since you are using django, the usual approach won't work. If you want to keep models in separate files, rather than in models.py, you have to take extra steps, outlined, for example, here.

Edit:
Well, I don't really know what the questioneer means when he mentions admin and whether or not it is related to the admin interface of django. My points still stand.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文