从字面上定义 Django 应用程序是什么?

what literally defines a django app?

我已经阅读了一些关于 "app" 在 django 中应该意味着什么的问题,但它们进入了应用程序的一般 purpose/use,这很重要,但不是什么应用程序字面上 "is"。例如,今天

时,我感到好奇
  1. 我删除了一个使用 django-admin startapp 作为应用程序安装的文件夹,并收到了一个错误,stackO 告诉我这是由于删除的应用程序名称驻留在我的 INSTALLED_APPS .清除名称后,我的应用程序再次运行

  2. 在项目的最高级别使文件夹变冷(只有 mkdir,没有 startapp)时,当尝试从真实应用程序导入名称时,我必须将我的项目添加到 sys.path 能够导入的列表。将此文件夹重新制作为应用程序后,导入不再是问题

我读过关于这个主题的问题,其中有像 "OK, I've got a models.py file, so it's an app" 这样的评论,但似乎很少有人真正了解应用程序是如何启动的。

我的问题是,

  1. 我有什么余地来修改 django 制作的应用程序?我可以删除它附带的所有文件(init 除外)并使其成为没有视图和模型的冷库吗?除了 init 之外,是否需要任何文件才能正常运行?

  2. 当我 运行 startapp 时 django 做了什么导致应用程序自动导入,当我使用 init[ 创建文件夹时没有这种效果=41=] 在其中(正如我所说的需要将项目路径添加到该文件夹​​中的 sys.path )。换句话说,django 命令 "startapp" 实际上是做什么来注册一个应用程序的?该操作在 django.core.management.templates.py 中,我今天阅读它并在 TemplateCommand.handle() 中看到引用应用程序或项目名称的内容,但无法确切地看到它是如何注册它们的。它导入 sys,但搜索 "sys.module" 不在文件

  3. 如果我想用 init 将一个空目录变成一个应用程序,我必须在 shell 中做什么才能做到这一点在不执行 startapp 的情况下更改?

谢谢

TLDR:Django 应用程序只是项目中的 Python 个包,除了 __init__.py 之外不需要任何文件来导入它。

我也经历过 Django 文档中对 "app" 的模糊解释,这让我在理解 Django 的概念之前研究了一般方案中的 "web app" 是什么我刚开始的时候。

一般定义,Web 应用程序是通过浏览器从服务器传输到客户端的任何程序。这可能是整个网站、网站中的某个组件(想想验证码、小部件、OAuth 等),或者网站的功能(例如与其他技术的集成,例如将页面导出为 PDF)。这些可以是或不是模块化组件,可移植性或不可移植性,并且在项目的源代码中是不同的或与其他东西混合。

由于一般的 "web app" 定义相当模糊,因此可能更容易想象 "Django app." 您的项目包含一个或多个应用程序,其中一些可能有文件,也可能没有。 从技术上讲, 您的应用程序可以包含除 __init__.py 之外的任何内容,并且仍然可以导入(它只是一个普通的 Python 包,尽管是一个无用的包)。您 可以 使它成为一个包含其他模块的库,但这看起来不符合 Python 风格,而且我强调尽可能将业务逻辑与我的网站源代码分开。

应用程序只是为您的项目做些事情的东西。很多人,包括我自己,喜欢问定义一个应用程序的问题是 "what does it do?" 如果你不能以简洁的方式回答这个问题(不包括 "and")那么你的应用程序可以分成几个不同的部分。这是为您推荐的,但如果您真的愿意,也可以违反此规则。在我的第一个 Django 项目中,我将整个网站放在一个应用程序文件夹中。管理成了一场噩梦,但我做到了。

视图和模型只是将您需要用于该应用程序的信息存储在一个地方的地方;如果您的整个网站只有一个大型应用程序,事情很快就会变得混乱和难以管理。那肯定是非 pythonic 的,Django 开发人员非常有意识地制作东西 "correctly."

至于技术细节,Django 项目是包。您可以使用 manage.py startproject 并检查您的 sys.path before/after。应用程序也是包,其中(据说)包含允许您 "app" 执行其预期功能的模块。您可以将它们用于任何事情、所有事情或什么都不做,但它们只是一个 Python 包,其中包含系统上整洁的小文件夹中的模块,可以为您的项目做些事情。

如果您还没有,可以在 Django 文档 here 中找到应用程序的快速概览。另外,这都是我的基本理解的产物,所以如果我的回答有任何问题,请告诉我。