高度なチュートリアル: 再利用可能アプリの書き方

この高度なチュートリアルは、 Tutorial 7 が終わったところから始まります。Web-poll を、新しいプロジェクトで再利用でき、他の人に共有できる独立した Python のパッケージへと変えていきましょう。

直近のチュートリアル 1 - 7 が終わっていないなら、一目通すことをおすすめします。例で作ったプロジェクトが以下の説明でも使われるからです。

ハリケーン H308-032C スーパートラッカー ハンドルキット ハンドルセット クロームメッキ XJR400R(98-00)新作大割引


☆DEGNER デグナー NB-15MAG マグネット式タンクバッグ カラー ブラック 【バイク用品】


ハリケーン H308-032C スーパートラッカー ハンドルキット ハンドルセット クロームメッキ XJR400R(98-00) 【メーカー在庫あり】 ハリケーン リアフェンダーレスキット キャッツアイ ミニ TYPE ビッグボーイ HA5774 HD店

↓↓↓【在庫あり】【イベント開催中!】 PMC ピーエムシー Z1/Z2 NHKステアリングダンパー Z1 (900SUPER4) Z2 (750RS/Z750FOUR);CUSCO(クスコ) クロモリロールバー KK4 7P インダッシュ 654265F;ビーナス ウィッシュ ZNE14G swift ブレーキパッド フロント用 スーパーハード, デラックス 荷室マット ビクトリー・ブラック ステップ無(穴無) マツダ ボンゴ ワイドロー/DX/GL/4ドア 1999年06月~ 選べる3タイプ ボンゴバン荷室05-F, 【送料無料】プレミアムスポーツタイヤ 225/40R18 ExtremeContact DW コンチネンタル Continental, 【USA在庫あり】 ムースレーシング MOOSE RACING 29mm ハンドルバー フレックス CR アルミ LOW 黒 0601-1758 HD店, プロジェクトミュー ブレーキパッド コンプBジムカーナ ■Projectμ COMP-B for GYMKHANA ノンアス 【品番:F304/R390】 4輪ディスク車用1台分 ホンダ ストリーム RN3/RN4 01.10~06.7;CUSCO(クスコ) 車高調 street RG2・4 リア14段 39062KCBF カワサキ純正 チャンバー プレマフラー 18004-0010 HD店↓↓↓15インチミラ カスタムL250、260系ENKEI オール オールフォー KCR マシニングブラック 5.0Jx15ZIEX ZE914F 165/50R15, ブリヂストン ECOPIA エコピア NH100 9月末迄 サマータイヤ 215/60R16 HotStuff 軽量設計!G.speed P-04 ホイールセット 4本 16インチ 16 X 6.5 +53 5穴 114.3, BMW F30/F31/F34 320i 328i 320ix 328ix スパークプラグセット NGK SILZKBR8D8S (4本セット), 【送料無料 MINI(F54)】 225/45R17 17インチ MOMO モモ ハイパースターEVO 7.5J 7.50-17 NITTO NT555 G2 サマータイヤ ホイール4本セット 輸入車 フジコーポレーション, 【D760】ハイゼットトラック [H26/9-][S500P / S510P] カジュアルG Bellezza ベレッツァ シートカバー


↓↓↓↓↓↓↓↓↓↓↓↓

17インチ サマータイヤ セット【適応車種:レガシィツーリングワゴン(BH系)】WEDS ライツレー DK ブラックメタリックポリッシュ 7.0Jx17ZIEX ZE914F 215/45R17, 純正同等/車検対応 マフラー ADエキスパード VY12(1.5 2WD) HST品番:027-78, DIXCEL/ディクセル ブレーキディスクローター SD フロント左右セット LANCIA DEDRA 1.6 ie 年式:89~99 型式:835AA/835AB/835AN 品番:SD261 2411S 備考必読ください, 15インチ サマータイヤ セット【適応車種:ムーブ(LA150、160系)】HOT STUFF エクシーダー E03 ダークシルバー 4.5Jx15Bluearth AE-01 165/55R15, 【USA在庫あり】 EBC イービーシー ブレーキローター スーパークロス コンツアー 直径250mm フロント 05年-15年 スズキ スチール 615488 HD店

グッドイヤー ベクター Vector 4Seasons Hybrid オールシーズンタイヤ 215/60R16 HotStuff Laffite ラフィット LE-04 ホイールセット 4本 16インチ 16 X 6.5 +38 5穴 114.3;アテンザスポーツ フロアマット [限定DX] カーマット アテンザスポーツ オリジナルマット 【国産 水洗い可 ファー ムートン 黒 ホワイト ベージュ ムラサキ オーシャン】【RCP】 15インチノートE12系ENKEI パフォーマンスライン PF01 マットブラック 6.5Jx15Bluearth エース AE50 185/65R15 【BR レガシィアウトバック クスコ】レガシィ アウトバック BRF オイルキャッチタンク;ESCO エスコ 洗車用品 アルコール手指消毒器

ヤマハ純正 キーセット 1B7-82023-10 HD店;【メーカー在庫あり】 日平機器(株) 日平 タフティーエアーリール HAP-210JT-BL JP

ハリケーン HE21S H308-032C スーパートラッカー ハンドルキット ハンドルセット クロームメッキ フルエキゾーストマフラー XJR400R(98-00)

Web アプリケーションの設計、開発、テスト、そしてメンテナンスには多大な労力が必要です TECNIUM テクニウム ピストン・ピストン周辺パーツ ピストン TM300 2006用 (PISTON FOR TM300 2006【ヨーロッパ直輸入品】) ピストン径:Φ71.94mm。そして多くの Python プロジェクト、 Django プロジェクトは共通の問題を抱えています。この繰り返し作業を減らせたら良いと思いませんか?

再利用は、 Python ではごく当たり前のことです。 Python Package Index (PyPI) には様々なパッケージが登録されており、それらはすべてあなたの Python プログラム上で使えます。 Django Packages にもプロジェクトに組み込める再利用可能なアプリケーションがあるので見てみてください。 Django 自体も単なる Python パッケージです 。つまり既存の Python パッケージまたは Django アプリケーションを使って、自分の Web プロジェクトを構成できるということです。必要なのはそのプロジェクト独自の部品を書くことだけです。

例えば、投票アプリケーション(ちょうど今まで作ってきたものと似たようなもの)を必要とするプロジェクトを新しく開始したとしましょう。どうやって投票アプリケーションを再利用可能にしますか?運のいいことに、その方法はすでに会得済みです。 チュートリアル3 では、 include を使ってプロジェクトレベルの URLconf から投票アプリを分離する方法を学びました。このチュートリアルでは、アプリケーションを新規のプロジェクトで使いやすいようにし、いつでも別の場所でインストール/利用できるようにします。

パッケージ?アプリ?

Python の
package を使うと、関連する Python コードをまとめて再利用しやすいようにできます。パッケージは、 Python コードのファイル ( 通称 "モジュール" ) を1つ以上含みます マスカロード クリアスクリーン メタリックノクターンブルー(タイガー)C6 通常スクリーン CHIC DESIGN(シックデザイン) ゼファーχ(ZEPHYR)96~09年。

パッケージは import foo.bar または from foo import bar でインポートできます。パッケージ内のディレクトリ (例えば polls) は __init__.py という特殊なファイルを、空のファイルでもいいので含む必要があります。

Django アプリケーション は単なる Python パッケージで、 Django プロジェクトで使うことのみを意図したものです。アプリは一般的な Django の慣例に則っているでしょう。例えば models 、 tests 、 urls 、 views のサブモジュールがあること、などです。

後に パッケージング という言葉を、他の人がインストールしやすいように Python パッケージを作るプロセスを表すのに用います。少し混乱するかもしれませんね。

プロジェクトと再利用可能アプリ

前のチュートリアルを終えると、プロジェクトはこのようになっているはずです:

mysite/
 manage.py
 mysite/
 __init__.py
 settings.py
 urls.py
 wsgi.py
 polls/
 __init__.py
 admin.py
 migrations/
 __init__.py
 0001_initial.py
 models.py
 static/
 polls/
 images/
 background.gif
 style.css
 templates/
 polls/
 detail.html
 index.html
 results.html
 tests.py
 urls.py
 views.py
 templates/
 admin/
 base_site.html


すでに mysite/templates を チュートリアル 7 で、 polls/templates を チュートリアル 3 で作成しました。今となっては、なぜテンプレートディレクトリをプロジェクトとアプリケーションに分けたかが明確にわかるかもしれませんね。投票アプリケーションに関する全ては polls にあります。アプリケーションが自己完結していて、新規のプロジェクトにも導入しやすくなっています。

今、 polls ディレクトリは新規の Django プロジェクトにコピーでき、すぐに再利用できる状態です。しかし公開するための準備が完璧というわけではありません。そのために、アプリをパッケージにして別の場所でインストールしやすいようにする必要があります。

事前に必要な物をインストールする

Python のパッケージングの現状は、複数のツールがあることで少しややこしいです。このチュートリアルでは setuptools をパッケージに使用します。これはおすすめのパッケージングツールです( forkされていた distribute はマージされました)。終わった後にアンインストールするために pip も使います。今はこの 2 つのパッケージをインストールしておいてください。分からなければ Django をpip でインストールする. を参照してください 【USA在庫あり】 ムース MOOSE Utility Division パワーコマンダー V 燃調キット 08年-11年 カワサキ KVF750 Brute Force 4x4 1020-1035 HD。 setuptools も同じ方法でインストールできます。

アプリケーションをパッケージングする

Python において パッケージング とは、特定のフォーマットでアプリを作っておくことです。このフォーマットは簡単にインストールして使えます。 Django 自体もこのようにパッケージ化されています。投票アプリのような小さなものでは、このプロセスはそれほど難しいものではありません。

  1. はじめに、 polls の親ディレクトリを、 Django プロジェクトの外に作りましょう。 django-polls というディレクトリにします。

    アプリケーションの名前を決める

    パッケージの名前を決めるときは、 PyPI のようなリソースをチェックして、すでにあるパッケージとの名前の衝突を避ける必要があります。 Django アプリケーションのパッケージを作って配布する際には、モジュール名の先頭に django- を付けるのがよいでしょう。こうすると、 Django アプリを探している人にとって、あなたのアプリが Django 特化のものであると判別しやすくなります。

    アプリケーションラベル (すなわち、アプリケーションパッケージへのパス(ドット区切り)の最後の部分) は INSTALLED_APPS の中で 必ず ユニークでなければなりません。 auth 、 admin 、 messages のようなDjango contrib packages と同じラベルを使うことは避けてください。

  2. polls ディレクトリを django-polls ディレクトリに移動する

  3. 以下の内容の django-polls/README.rst という名前のファイルを作成します:

    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::
     path('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.
    
    
    
    
    
  4. django-polls/LICENSE ファイルを作成します。ライセンスの選択はこのチュートリアルの範疇を超えていますが、ライセンスなしで公にリリースされたコードは 役立たず であると言えば十分です。 Django と多くの Django 互換アプリケーションはBSDライセンスの元に配布されます。でもどのライセンスを選択するかは自由です。ライセンスの選択は、誰がコードを使え得るかに影響すると注意してください。

  5. 次に setup.py ファイルを作りましょう。これはアプリケーションがどのようにビルド、インストールされるかを提供するものです ヨシムラ BAZZAZ Z-FI ZX10R 16 BZ-F4414 HD店。このファイルの網羅的な説明はこのチュートリアルの範疇を超えていますが、 setuptools docs には役立つ説明があります プロジェクトミュー ブレーキパッド HC-CS リア用 WiLL VS ZZE128 01.4~ 送料無料。以下のように django-polls/setup.py ファイルを作ってみましょう:

    django-polls/setup.py
    import os
    from setuptools import find_packages, setup
    with open(os.path.join(os.path.dirname(__file__), 'README.rst')) as readme:
     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(
     name='django-polls',
     version='0.1',
     packages=find_packages(),
     include_package_data=True,
     license='BSD License', # example license
     description='A simple Django app to conduct Web-based polls.',
     long_description=README,
     url='https://www.example.com/',
     author='Your Name',
     author_email='yourname@example.com',
     classifiers=[
     'Environment :: Web Environment',
     'Framework :: Django',
     'Framework :: Django :: X.Y', # replace "X.Y" as appropriate
     'Intended Audience :: Developers',
     'License :: OSI Approved :: BSD License', # example license
     'Operating System :: OS Independent',
     'Programming Language :: Python',
     'Programming Language :: Python :: 3.5',
     'Programming Language :: Python :: 3.6',
     'Topic :: Internet :: WWW/HTTP',
     'Topic :: Internet :: WWW/HTTP :: Dynamic Content',
     ],
    )
    
    
    
    
    
  6. デフォルトでは、パッケージには Python のモジュールとパッケージだけがまとめられます。追加のファイルを含めるには、MANIFEST.in というファイルを作成する必要があります。前のステップで挙げた setuptools のドキュメントには、このファイルについて詳しい説明があります。テンプレート、README.rst、および LICENSE をパッケージに含めるには、django-polls/MANIFEST.in というファイルを作成し、その中に次のように書きます。

    django-polls/MANIFEST.in
    include LICENSE
    include README.rst
    recursive-include polls/static *
    recursive-include polls/templates *
    
  7. アプリケーションの詳細なドキュメントを含めるのは、任意ですが推奨されます。空のディレクトリ django-polls/docs を将来のドキュメンテーションのために作っておきましょう。 django-polls/MANAFEST.in に行を追加しておいてください:

    recursive-include docs *
    
    
    

    MANIFEST.in に対象のファイルを追加しないと docs ディレクトリがパッケージに含まれないことに注意してください。多くの Django アプリではドキュメントを readthedocs.org のようなサイトを通して提供しています。

  8. python setup.py sdist でパッケージをビルドしてみましょう (django-polls 内で実行してください) 。これによって dist というディレクトリと、新しいパッケージである django-polls-0.1.tar.gz が作られます。

    For more information on packaging, see Python's Tutorial on Packaging and Distributing Projects.

    自分のパッケージを使ってみる

    polls ディレクトリはプロジェクト外に移動したので、これはもう動きません。代わりにできたての django-polls パッケージを使ってみましょう。

    ユーザーライブラリとしてインストールする

    以下のステップは django-polls をユーザーライブラリとしてインストールするものです。ユーザー単位でのインストールはシステム全体でのインストールよりも多くの利点があります。管理者アクセス権を持っていないシステム上で使用可能というだけでなく、パッケージがシステムサービスやマシン上の他ユーザーに影響を与えるのを防げます。

    ユーザー単位でのインストールは依然、そのユーザーのシステムツールの振る舞いに影響をあたえます。なので virtualenv はより確実な解決になります (下記を参照してください) 。

    1. パッケージをインストールするためには、pip を利用してください (すでに インストール していますよね?):

      クロームメッキ ハリケーン XJR400R(98-00) H308-032C ハンドルセット ハリケーン クロームメッキ スーパートラッカー ハンドルキット

      pip install --user django-polls/dist/django-polls-0.1.tar.gz
      
      
      
      
    2. 運が良ければ Django プロジェクトは再度、正常に動作します。確認するために再びサーバーを起動します。

    3. パッケージをアンインストールするには pip を使います:

      pip uninstall django-polls
      
      
      
      
      
      

      アプリを公開する

      django-polls のパッケージを作り、テストしました。世界に共有するときです!これが単なる例でなければこうします:

      virtualenv に Python パッケージをインストールする

      これまでは投票アプリをユーザーライブラリにインストールしてきました。これにはいくつか欠点があります:

      • ユーザーライブラリの変更はシステム上の他の Python ソフトウェアに影響を与えるおそれがあります
      • このパッケージの複数バージョン (もしくは同じ名前の別のもの) を実行できません

      通常このような問題が起こるのは、複数の Django プロジェクトを管理している場合だけです。一番の解決方法は、 virtualenv を利用することです。このツールを使えば、複数の独立した Python 環境を持つことができます。各 Python 環境はそれぞれに、ライブラリのコピーやパッケージの名前空間を持ちます。

      Back to Top

      追加的な情報