前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django下重用自己写的app

Django下重用自己写的app

作者头像
菲宇
发布2019-08-14 11:02:28
1.2K0
发布2019-08-14 11:02:28
举报
文章被收录于专栏:菲宇

可重用很重要

设计、构建、测试和维护一个网页应用有许多工作要做。许多Python 和 Django 项目都有常见的共同问题。可重用将会节省这些重复性工作。

可重用性在Python 中是一种常见的方式。Python包索引 (PyPI) 具有广泛的包,你可以在你自己的Python程序中使用。查阅一下Django Packages中已经存在的可重用的应用,你可以结合它们到你的项目。Django 自身也只是一个Python 包。这意味着你可以获取已经存在的Python包和Django应用并将它们融合到你自己的网页项目。你只需要编写你项目的独特的部分。

假设您正在开始一个新项目,需要一个像我们一直在进行的投票应用程序。你如何让该应用可重用?幸运的是,你已经在正确的道路上。在教程 3中,我们看到我们可以如何使用include将投票应用从项目级别的URLconf 解耦。在本教程中,我们将更进一步,让你的应用在新的项目中容易地使用并随时可以发布给其它人安装和使用。

包?应用?

Python 按照简单重用的方式,将具有相关性的Python代码归为一组。一个包包含一个或多个Python文件(也叫做“模块”)。

包可以通过import foo.bar 或from foo import bar 导入。如果一个目录(例如polls)想要形成一个包,它必须包含一个特殊的文件__init__.py,即使这个文件为空。

一个Django 应用 只是一个Python包,它特意用于Django项目中。一个应用可以使用常见的Django 约定,例如具有models、tests、urls和views 子模块。

安装一些前提条件

Python 打包的目前状态因为有多种工具而混乱不堪。对于本教程,我们打算使用setuptools来构建我们的包。它是推荐的打包工具(已经与distribute 分支合并)。我们还将使用pip来安装和卸载它。现在你应该安装这两个包。如果你需要帮助,你可以参考如何使用pip安装Django。你可以使用同样的方法安装setuptools。

打包你的应用

Python 打包 会将你的应用预处理成一种特殊的格式, 这样安装和使用就会变得简单。Django 自己是以非常相似的方式打包起来的。对于一个像polls这样的小应用,这个过程不是太难。

  1. 首先,在你的Django项目之外,为polls创建一个父目录。称这个目录为django-polls。 为你的应用选择一个名字 当为你的包选择一个名字时,检查一下PyPI中的资源以避免与已经存在的包有名字冲突。当创建一个要发布的包时,在你的模块名字前面加上django-通常很有用。 这有助于其他正在查找Django应用的人区分你的应用是专门用于Django的。 应用的标签(应用的包的点分路径的最后部分)在INSTALLED_APPS必须唯一。避免使用与Django的contrib 包 中任何一个使用相同的标签,例如auth、admin和messages。

将polls 目录移动到django-polls目录。

创建一个包含以下内容的文件django-polls/README.rst:

代码语言:javascript
复制
 django-polls/README.rst
=====
Polls
=====
Polls is a simple Django app to conduct Web-based polls. For each
question, visitors can choose between a fixed number of answers.
Detailed documentation is in the "docs" directory.
Quick start
-----------
1. Add "polls" to your INSTALLED_APPS setting like this::
    INSTALLED_APPS = (
        ...
        'polls',
    )
2. Include the polls URLconf in your project urls.py like this::
    url(r'^polls/', include('polls.urls')),
3. Run `python manage.py migrate` to create the polls models.
4. Start the development server and visit http://127.0.0.1:8000/admin/
   to create a poll (you'll need the Admin app enabled).
5. Visit http://127.0.0.1:8000/polls/ to participate in the poll.
--------------------- 
版权声明:本文为CSDN博主「菲宇」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/bbwangj/article/details/98062961
  1. 创建一个django-polls/LICENSE文件。如何选择License超出本教程的范围,但值得一说的是, 公开发布的代码如果没有License是毫无用处的。Django和许多与Django兼容的应用以BSD License 发布;然而,你可以随便挑选自己的License。只需知道你所选择的License,将决定谁能使用你的代码.
  2. 下一步我们将创建一个setup.py 文件,它提供如何构建和安装该应用的详细信息。该文件完整的解释超出本教程的范围,setuptools 文档 有很好的解释。创建一个文件django-polls/setup.py,其内容如下:

django-polls/setup.py

import os

from setuptools import setup

with open(os.path.join(os.path.dirname(__file__), 'README.rst')) as readme:

代码语言:txt
复制
README = readme.read()

allow setup.py to be run from any path

os.chdir(os.path.normpath(os.path.join(os.path.abspath(__file__), os.pardir)))

setup(

代码语言:txt
复制
name='django-polls',
代码语言:txt
复制
version='0.1',
代码语言:txt
复制
packages=['polls'],
代码语言:txt
复制
include\_package\_data=True,
代码语言:txt
复制
license='BSD License',  # example license
代码语言:txt
复制
description='A simple Django app to conduct Web-based polls.',
代码语言:txt
复制
long\_description=README,
代码语言:txt
复制
url='http://www.example.com/',
代码语言:txt
复制
author='Your Name',
代码语言:txt
复制
author\_email='yourname@example.com',
代码语言:txt
复制
classifiers=[
代码语言:txt
复制
    'Environment :: Web Environment',
代码语言:txt
复制
    'Framework :: Django',
代码语言:txt
复制
    'Intended Audience :: Developers',
代码语言:txt
复制
    'License :: OSI Approved :: BSD License', # example license
代码语言:txt
复制
    'Operating System :: OS Independent',
代码语言:txt
复制
    'Programming Language :: Python',
代码语言:txt
复制
    # Replace these appropriately if you are stuck on Python 2.
代码语言:txt
复制
    'Programming Language :: Python :: 3',
代码语言:txt
复制
    'Programming Language :: Python :: 3.2',
代码语言:txt
复制
    'Programming Language :: Python :: 3.3',
代码语言:txt
复制
    'Topic :: Internet :: WWW/HTTP',
代码语言:txt
复制
    'Topic :: Internet :: WWW/HTTP :: Dynamic Content',
代码语言:txt
复制
],

)


版权声明:本文为CSDN博主「菲宇」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。

原文链接:https://cloud.tencent.com/developer/article/1486484

默认只有Python模块和包会包含进包中。如果需要包含额外的文件,我们需要创建一个MANIFEST.in文件。上一步提到的setuptools 文档对这个文件有更详细的讨论。如果要包含模板、README.rst和我们的LICENSE 文件,创建一个文件django-polls/MANIFEST.in,其内容如下:

代码语言:javascript
复制
django-polls/MANIFEST.in
include LICENSE
include README.rst
recursive-include polls/static *
recursive-include polls/templates *
 
  1. 将详细的文档包含进你的应用中,它是可选的,但建议你这样做。创建一个空的目录django-polls/docs用于将来存放文档。向django-polls/MANIFEST.in添加另外一行: recursive-include docs * 注意docs不会包含进你的包中除非你添加一些文件到它下面。许多Django应用还通过类似readthedocs.org这样的站点提供它们的在线文档.
  2. 试着通过python setup.py sdist 构建你的包(从django-polls的内部运行)。这会创建一个dist目录并构建一个新包:django-polls-0.1.tar.gz。

更多关于打包的信息,参见Python 的 打包和分发项目的教程

使用你自己的包

因为,我们将polls 目录移到项目的目录之外,它不再工作了。我们将通过安装我们的新的django-polls包来修复它。

安装成某个用户的库

以下的步骤将安装django-polls 成某个用户的库。用户级别的安装比系统级别的安装有许多优点,例如将包运行在普通用户级别上不但不会影响系统服务还不会影响其他用户

注意根据用户的安装仍然可以影响以该用户身份运行的系统工具,所以virtualenv 是更健壮的解决办法(见下文)。

  1. 安装这个包,使用pip(你已经安装好它了,对吧?): pip install --user django-polls/dist/django-polls-0.1.tar.gz
  2. 幸运的话,你的Django 项目现在应该又能正常工作了。请重新运行服务器以证实这点。
  3. 若要卸载这个包,使用pip: pip uninstall django-polls

发布你的应用:

既然我们已经打包并测试过django-polls,是时候与世界共享它了!如果它不仅仅是个例子,你现在可以:

使用 virtualenv 安装Python 包

前面,我们将poll 安装成一个用户的库。它有一些缺点:

  • 修改这个用户的库可能影响你的系统上的其它Python 软件。
  • 你将不可以运行这个包的多个版本(或者具有相同名字的其它包)。

特别是一旦你维护几个Django项目,这些情况就会出现。如果确实出现,最好的解决办法是使用virtualenv。这个工具允许你维护多个分离的Python环境,每个都具有它自己的库和包的命名空间。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019年08月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 可重用很重要
  • 安装一些前提条件
  • 打包你的应用
  • allow setup.py to be run from any path
    • 使用你自己的包
      • 发布你的应用:
        • 使用 virtualenv 安装Python 包
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档