Django tutorial 2.
このページには、第2部から第4部までの内容が含まれています.
最初の設定pyをチェックして
データベースのデフォルトはdefault sqliteです.
他のデータベースを使用する場合
ENGINE : 'django.db.backends.sqlite3', 'django.db.backends.postgresql',
'django.db.backends.mysql',
'django.db.backends.oracle'
上の値で修正して適用します.
TIME_ZONE
この図のTIME ZONE='UTC.
私たちは韓国人なので、asia/soulに変えましょう.
INSTALLED_APPS
前のtutorial 1では、インストールされているappsを見てみましょう.
デフォルトでは、INSTALLED APPSには、Djangoに付属する次のアプリケーションが含まれています.
django.contrib.admin–管理用のサイト.すぐに使えます.
django.contrib.auth–認証システム.
django.contrib.contenttypes–コンテンツタイプのフレームワークに使用します.
django.contrib.セッション–セッションフレームワーク.
django.contrib.Messages–メッセージングフレームワーク.
django.contrib.staticfiles–静的ファイルのフレームワークを管理します.
views?
-django特定の機能とテンプレートを提供するWebページ
たとえば、エンベロープは次のとおりです.ホームページ 詳細ディレクトリページ 日付ページ コメント機能等
同じビューページを持つことができます. 以下の4ページを作成してみます.
新規ビューコンテンツの作成
viewsを作成した場合はurls
に接続します
正式文書の説明
When somebody requests a page from your website – say, “/polls/34/”, Django will load the mysite.urls Python module because it’s pointed to by the ROOT_URLCONF setting.
->ブラウザが「/policy/34/」を要求した場合
It finds the variable named urlpatterns and traverses the patterns in order. After finding the match at 'polls/', it strips off the matching text ("polls/") and sends the remaining text – "34/"– to the ‘polls.urls’ URLconf for further processing.
->urlpatternsで「policy/」セクションを検索し、後のテキスト「34/」を送信します.
There it matches '/', resulting in a call to the detail() view like so:
->この「34/」はurlsです.pyはpath(「/」,views.detail)セクションであるため、ビューを呼び出します.
すなわち
民調/1コールdata:image/s3,"s3://crabby-images/94d79/94d797d0d6c3fe31aa61c13d406618f9c4c352db" alt=""
ポーリング/1/resultsコールdata:image/s3,"s3://crabby-images/e8f2c/e8f2c77d0b72b51797b953ac3354e8681043fb19" alt=""
投票/1/投票コールdata:image/s3,"s3://crabby-images/2846d/2846d3fead3f93e659ed3c974fdd6e7442976f54" alt=""
ということで
viewを作動させるために、
上記の要求内容を含むHttpResponseオブジェクトを返すか、異常(例えばHttp 404)が発生する必要があります.
HttpResponse
HttpRequestオブジェクトを受信してHttpResponseオブジェクトを返しますが、DjangoはHttpResponseを提供していません.私たちは自分でHttpResponseを作成する必要があります.
まずpolicydirにtemplateddirを作成し、indexを作成します.htmlファイルを作成した後
get templateがどのような方法であるかを決定するには、altキーを使用して確認し、get template(template name)を使用してtemplateをロードします.
templateをロードしてcontextを渡します.
でもこうやってcontextでHttpResponseの部分に対してよく書く部分
これらのよく使われるコードを簡単にしたいです.だからdjangoにもrenderモジュールがあります.
(常にdjangoページでモジュールと関数パラメータを直接チェック)
このように描くと.
HttpResponseはある程度完了しましたが、異常が発生した場合のコードを記述する必要があります.
まずtemplates>policy>detailです.html作成後
views.pyに戻る
get objector 404 obhectが存在しない場合、Http 404が生成される.
この関数はget関数であるdict値であり、listを返すとget list or 404もある.
そうだそうです.
しかし実際にDjangoプロジェクトを始めると世論調査のようなアプリがたくさんありますが、それらの間のURL名はどう違うのでしょうか?urlconfに名前空間を追加するそうです.
urls.pyで
url「policy:detail」に変更します.
request.POSTは、ユーザが鍵によって送信されたデータにアクセスできるようにする辞書などのオブジェクト、要求である.POST「選択」は、選択した調査のIDを文字列として返す.request.POSTの値は常に文字列です.
DjangoはGET資料へのアクセスを同様に要求する.GET–ただし、POSTのみでデータの変更を要求するため、要求コードを明確にしてください.POSTを使用しています.
POST資料が選択されていない場合は、request.POST[選択]にKeyErrorが表示されます.上のコードではKeyErrorがチェックされ、選択されていない場合はエラーメッセージと調査テーブルが返されます.
アンケート数が増加すると、コードは、従来のHttpResponseRedirectではなく、HttpResponseRedirectを返します.HttpResponseRedirectは、ユーザーが再送信するURLである引数を受信します.(この場合、URLの設定方法を見てください:)
As the Python comment above points out, you should always return an HttpResponseRedirect after successfully dealing with POST data. This tip isn’t specific to Django; it’s good Web development practice in general. -> POSTデータ処理後はHttpResponseRedirectに戻ります!
この例では、HttpResponseRedirectジェネレータでreverse()関数を使用します.この関数は、ビュー関数でURLをハードコーディングしないようにします.コントロールを渡すビューの名前とURLモードの変数部分を組み合わせてそのビューを指します.ここでは、チュートリアル3章で設定したURLConfを使用します.この逆()呼び出しは、次の文字列を返します.
0. Database setup
最初の設定pyをチェックして
data:image/s3,"s3://crabby-images/e633b/e633ba2fa952902011cf49672511039c5061556f" alt=""
データベースのデフォルトはdefault sqliteです.
他のデータベースを使用する場合
ENGINE : 'django.db.backends.sqlite3', 'django.db.backends.postgresql',
'django.db.backends.mysql',
'django.db.backends.oracle'
上の値で修正して適用します.
TIME_ZONE
data:image/s3,"s3://crabby-images/18e70/18e70fafca8b7c7628649392083119488641f2e3" alt=""
この図のTIME ZONE='UTC.
私たちは韓国人なので、asia/soulに変えましょう.
INSTALLED_APPS
data:image/s3,"s3://crabby-images/b4ae0/b4ae030c15c1c862e150b0062acb6b7656f00358" alt=""
前のtutorial 1では、インストールされているappsを見てみましょう.
デフォルトでは、INSTALLED APPSには、Djangoに付属する次のアプリケーションが含まれています.
django.contrib.admin–管理用のサイト.すぐに使えます.
django.contrib.auth–認証システム.
django.contrib.contenttypes–コンテンツタイプのフレームワークに使用します.
django.contrib.セッション–セッションフレームワーク.
django.contrib.Messages–メッセージングフレームワーク.
django.contrib.staticfiles–静的ファイルのフレームワークを管理します.
1.VIEWSの作成
views?
-django特定の機能とテンプレートを提供するWebページ
たとえば、エンベロープは次のとおりです.
同じビューページを持つことができます.
data:image/s3,"s3://crabby-images/6c9ab/6c9abbc6f93d3fd6e747bdb4c56afa7bf0174681" alt=""
新規ビューコンテンツの作成
data:image/s3,"s3://crabby-images/13208/1320821b46bbbad929e7f69c632e842cba54bc2e" alt=""
viewsを作成した場合はurls
data:image/s3,"s3://crabby-images/e5bba/e5bba5a22e5cdf9528fa9ff3ff7968b73d1f614e" alt=""
正式文書の説明
When somebody requests a page from your website – say, “/polls/34/”, Django will load the mysite.urls Python module because it’s pointed to by the ROOT_URLCONF setting.
->ブラウザが「/policy/34/」を要求した場合
It finds the variable named urlpatterns and traverses the patterns in order. After finding the match at 'polls/', it strips off the matching text ("polls/") and sends the remaining text – "34/"– to the ‘polls.urls’ URLconf for further processing.
->urlpatternsで「policy/」セクションを検索し、後のテキスト「34/」を送信します.
There it matches '
->この「34/」はurlsです.pyはpath(「
すなわち
民調/1コール
data:image/s3,"s3://crabby-images/94d79/94d797d0d6c3fe31aa61c13d406618f9c4c352db" alt=""
ポーリング/1/resultsコール
data:image/s3,"s3://crabby-images/e8f2c/e8f2c77d0b72b51797b953ac3354e8681043fb19" alt=""
投票/1/投票コール
data:image/s3,"s3://crabby-images/2846d/2846d3fead3f93e659ed3c974fdd6e7442976f54" alt=""
ということで
viewを作動させるために、
上記の要求内容を含むHttpResponseオブジェクトを返すか、異常(例えばHttp 404)が発生する必要があります.
HttpResponse
HttpRequestオブジェクトを受信してHttpResponseオブジェクトを返しますが、DjangoはHttpResponseを提供していません.私たちは自分でHttpResponseを作成する必要があります.
まずpolicydirにtemplateddirを作成し、indexを作成します.htmlファイルを作成した後
data:image/s3,"s3://crabby-images/d0aff/d0aff9515cd6a75d69f3c6c2e4b3328ed9ca0bef" alt=""
from django.http import HttpResponse
from django.template import loader
from .models import Question
def index(request):
latest_question_list = Question.objects.order_by('-pub_date')[:5]
template = loader.get_template('polls/index.html')
context = {
'latest_question_list': latest_question_list,
}
return HttpResponse(template.render(context, request))
template> index.htmlに接続するコードの作成get templateがどのような方法であるかを決定するには、altキーを使用して確認し、get template(template name)を使用してtemplateをロードします.
data:image/s3,"s3://crabby-images/c6e56/c6e565d5d51bb4fcf42f9526406373300e638823" alt=""
templateをロードしてcontextを渡します.
でもこうやってcontextでHttpResponseの部分に対してよく書く部分
これらのよく使われるコードを簡単にしたいです.だからdjangoにもrenderモジュールがあります.
data:image/s3,"s3://crabby-images/2f6d9/2f6d9ce978f50f5ccea0aa15c9a5c5424b8c7e84" alt=""
data:image/s3,"s3://crabby-images/57e83/57e83525a0a0d078b1942d6d61c645a5cae26d75" alt=""
このように描くと.
from django.shortcuts import render
from .models import Question
def index(request):
latest_question_list = Question.objects.order_by('-pub_date')[:5]
context = {'latest_question_list': latest_question_list}
return render(request, 'polls/index.html', context)
和弦がこんなにきれいになった.(でも最近レンダーをあまり使わないそうなので我慢)HttpResponseはある程度完了しましたが、異常が発生した場合のコードを記述する必要があります.
まずtemplates>policy>detailです.html作成後
{{question}}
入力します.views.pyに戻る
from django.shortcuts import get_object_or_404, render
from .models import Question
# ...
def detail(request, question_id):
question = get_object_or_404(Question, pk=question_id)
return render(request, 'polls/detail.html', {'question': question})
に記入get objector 404 obhectが存在しない場合、Http 404が生成される.
data:image/s3,"s3://crabby-images/88c1b/88c1b0f9a0a85cb061cd3e1301ea1a9c3bc66c85" alt=""
data:image/s3,"s3://crabby-images/21a33/21a331cb8d596fa8834bfbbbcc3a971dc6ece9cb" alt=""
そうだそうです.
しかし実際にDjangoプロジェクトを始めると世論調査のようなアプリがたくさんありますが、それらの間のURL名はどう違うのでしょうか?urlconfに名前空間を追加するそうです.
urls.pyで
from django.urls import path
from . import views
app_name = 'polls'
urlpatterns = [
path('', views.index, name='index'),
path('<int:question_id>/', views.detail, name='detail'),
path('<int:question_id>/results/', views.results, name='results'),
path('<int:question_id>/vote/', views.vote, name='vote'),
]
app name=「世論調査」を追加data:image/s3,"s3://crabby-images/d1c81/d1c81df8e03094abe5b8c04ef4bf8d7ec425f548" alt=""
url「policy:detail」に変更します.
2.投票フォームの設定
from django.http import HttpResponse, HttpResponseRedirect
from django.shortcuts import get_object_or_404, render
from django.urls import reverse
from .models import Choice, Question
# ...
def vote(request, question_id):
question = get_object_or_404(Question, pk=question_id)
try:
selected_choice = question.choice_set.get(pk=request.POST['choice'])
except (KeyError, Choice.DoesNotExist):
# Redisplay the question voting form.
return render(request, 'polls/detail.html', {
'question': question,
'error_message': "You didn't select a choice.",
})
else:
selected_choice.votes += 1
selected_choice.save()
# Always return an HttpResponseRedirect after successfully dealing
# with POST data. This prevents data from being posted twice if a
# user hits the Back button.
return HttpResponseRedirect(reverse('polls:results', args=(question.id,)))
上記のコードには、このチュートリアルでは説明されていないものが含まれています.request.POSTは、ユーザが鍵によって送信されたデータにアクセスできるようにする辞書などのオブジェクト、要求である.POST「選択」は、選択した調査のIDを文字列として返す.request.POSTの値は常に文字列です.
DjangoはGET資料へのアクセスを同様に要求する.GET–ただし、POSTのみでデータの変更を要求するため、要求コードを明確にしてください.POSTを使用しています.
POST資料が選択されていない場合は、request.POST[選択]にKeyErrorが表示されます.上のコードではKeyErrorがチェックされ、選択されていない場合はエラーメッセージと調査テーブルが返されます.
アンケート数が増加すると、コードは、従来のHttpResponseRedirectではなく、HttpResponseRedirectを返します.HttpResponseRedirectは、ユーザーが再送信するURLである引数を受信します.(この場合、URLの設定方法を見てください:)
As the Python comment above points out, you should always return an HttpResponseRedirect after successfully dealing with POST data. This tip isn’t specific to Django; it’s good Web development practice in general. -> POSTデータ処理後はHttpResponseRedirectに戻ります!
data:image/s3,"s3://crabby-images/a4ca7/a4ca7cc4809a992c619b79b6b0ccbd1184281db2" alt=""
この例では、HttpResponseRedirectジェネレータでreverse()関数を使用します.この関数は、ビュー関数でURLをハードコーディングしないようにします.コントロールを渡すビューの名前とURLモードの変数部分を組み合わせてそのビューを指します.ここでは、チュートリアル3章で設定したURLConfを使用します.この逆()呼び出しは、次の文字列を返します.
Reference
この問題について(Django tutorial 2.), 我々は、より多くの情報をここで見つけました https://velog.io/@jake93/Django-tutorial-2テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol