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

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

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

ドクターダリウス(シューズ)ブラック/25.5~26.0cm DD00201 1足【条件付返品可】【激安通販店】


『10%OFFクーポン対象』BAUERFEIND(バウアーファインド)「ゲニュ TRAIN黒 =5 62020403」膝(ひざ)用サポーター【KPI】


ドクターダリウス(シューズ)ブラック/25.5~26.0cm DD00201 1足【条件付返品可】 《セット販売》 花王 めぐりズム 蒸気でグッドナイト 首もと あったかシート 無香料 (12枚入)×12個セット

↓↓↓ブラウン オーラルB GENIUS(ジーニアス) プロフェッショナル(D7015355XCPN) × 1台;コスメデコルテ COSME DECORTE AQMW リペアエマルジョン 200mL ※お一人様1個限り;H&R ホイールスペーサー Porsche 993 50mm 5穴 PCD130 71.6φ DRMタイプ, ミシュラン Premier プレミア LTX サマータイヤ 225/60R17 MANARAY SCHNEDER シュナイダー DR-01 ホイールセット 4本 17インチ 17 X 7 +53 5穴 114.3, 【メーカー在庫あり】 サンドビック(株) サンドビック T-Max P ポジチップ用シャンクバイト PRGCR 3225P 12 JP, 【送料無料】 ロッキー ルーフキャリア SBシリーズ トヨタ カローラ スプリンター 90・ 100系ワゴン用 SB-01 ルーフラック 横山製作所 ロッキープラス, ピボット(PIVOT) デジタルモニターDMC-G(水温,エンジン回転,電圧) トヨタ カローラアクシオ NZE141/144 1NZ-FE H18.10~;【正規品・送料無料】ディプティック キャンドル ウード+コフレ5700円 【送料無料・まとめ買い×9個セット】花王 ブローネ 泡カラー 7 黒みのダークブラウン 108ml↓↓↓KLOCK WERKS クロックワークス フロントフェンダーキット VAQ16-18PRC C 【KIT FNDR F VAQ16-18PRC C [1402-0335]】, 2輪 D.I.D VXシリーズ シールチェーン ゴールド 120L KTM 620 デュークII 620cc 1999年~2000年, ステップワゴン シートカバー RK1 RK2 RK5 RK6 一台分 クラッツィオ EH-2523 キルティング タイプ シート 内装, [TGS-BC401A] TGS センターブリッジカバー (カーボン) デリカD:5 ROADEST専用, SUZUKI スズキ 純正 ALTO アルト リヤバンパーロアガーニッシュ ピュアレッド (2016.12~仕様変更) 99000-99076-AG1

SHISEIDO AQUA INTENSIVE ダメージが気になる方 シャンプー 450ml ×3個 & トリートメント2 450g ×3個 & マスク 680g ×3個 & マルチケアミルク 1800ml ×3個 セット 資生堂 アクアインテンシブ 送料無料

↓↓↓↓↓↓


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

アレス ハードウェーブレギュラー 5V(長さ:約50cm(加工前70cm) ロッドの太さ:13mm 100g), 【正規品・送料無料】シャネル ルージュ ココ リップ ブラッシュ 416 ティージング ピンク(5.5g)+No5ミルキーバスセット, 【送料無料】 ルベル プロエディット ヘアスキン オアシスリラクシング 360g ×3個 セット 乾燥が気になる地肌をすこやかに LebeL proedit, 【送料無料】ピジョン ハビナース リンスインシャンプー 弱酸性 20リットル入り(業務用), 【お年玉コフレ・正規品・送料無料】COSMEお年玉グロスコフレSET&メルヴィータ メルヴィータオム ウッドエッセンシャル フェースクレンジングジェル(100ml)

+P6倍!アクセーヌ フューチャーサイクル クリーミィセラム 45g[代引選択不可];【PU20倍】ミルボン -DEESSE'S- ディーセス ノイ ドゥーエ ウィローリュクス ヘアトリートメント 1000g詰替【ヘアカラー用】 カネボウ トワニー エスティチュード ラグジェ フェースアップ リフレッシャー 60mL TWANY マリールイズ リフトレーション クリアジェル100ml /48点入り(代引き不可);【お年玉コフレ・正規品・送料無料】COSMEお年玉グロスコフレSET&サンタマリアノヴェッラ ルームアロマ タボレッタラベンダー(2枚入り)

【特典付】LADONNA リュミエール(Lumiere) アロマディフューザー  ADF29ーLM/Aroma Diffuser/ラドンナ(LDN)【送料無料】【在庫有】【】;新春セール ラルフローレン ロマンス EDP 50ml 「コンパクト便対応可」 RALPH LAUREN ROMANCE

ドクターダリウス(シューズ)ブラック/25.5~26.0cm エステワゴン) DD00201 1足【条件付返品可】 エクセルS.Cクレンジングクリーム(105g)+お肌ツルツルセット

Web アプリケーションの設計、開発、テスト、そしてメンテナンスには多大な労力が必要です 【正規品・送料無料】ジルスチュアート ブレンドブラッシュブロッサム 04good afternoon(7.5g)+お肌ツルツルセット。そして多くの Python プロジェクト、 Django プロジェクトは共通の問題を抱えています。この繰り返し作業を減らせたら良いと思いませんか?

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

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

パッケージ?アプリ?

Python の
package を使うと、関連する Python コードをまとめて再利用しやすいようにできます。パッケージは、 Python コードのファイル ( 通称 "モジュール" ) を1つ以上含みます メンズウィッグ カジュアルスタイル Mサイズ ダークブラウン 全体的に短めで動きが出しやすいスタイル。

パッケージは 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 でインストールする. を参照してください パイヨPayotUni Skin Mousse Velours - Unifying Skin-Perfecting Cream 【海外直送】。 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 ファイルを作りましょう。これはアプリケーションがどのようにビルド、インストールされるかを提供するものです 【12個まとめ買い】モウガインセント 薬用育毛トニック プレミアムクール 250g特大 ×12個。このファイルの網羅的な説明はこのチュートリアルの範疇を超えていますが、 setuptools docs には役立つ説明があります お役立ちグッズ アルタン ハンドブラシ 取り付け用粘着シート付 2本×12個セット 788。以下のように 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 を利用してください (すでに インストール していますよね?):

      ドクターダリウス(シューズ)ブラック/25.5~26.0cm ドクターダリウス(シューズ)ブラック/25.5~26.0cm 1足【条件付返品可】 DD00201 1足【条件付返品可】

      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

      追加的な情報