このページの翻訳:
- 日本語 (ja)
- English (en)
最近の更新
- 03 Zed editor 設定 [Windowsでビルド]
- 09 ↷ 50_dialy:2025:09:09 から 50_dialy:2025:09:08 へページを名称変更しました。
- 06 ↷ 50_dialy:2025:06 から 50_dialy:2025:09:06 へページを移動しました。
最近の更新
Django環境は、こちら で用意。
test_project
docker-compose run web django-admin.py startapp [アプリ名]
or
docker-compose exec web python manage.py startapp [アプリ名]
例:
docker-compose exec web python manage.py startapp testapp
アプリ作成時点だと下記のようになってます。
プロジェクト名は「test_project」、アプリ名は「testapp」を例に説明
# tree ./
./
├── db.sqlite3
├── manage.py
├── test_project
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-38.pyc
│ │ ├── settings.cpython-38.pyc
│ │ ├── urls.cpython-38.pyc
│ │ └── wsgi.cpython-38.pyc
│ ├── asgi.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
└── testapp
├── __init__.py
├── admin.py
├── apps.py
├── migrations
│ └── __init__.py
├── models.py
├── tests.py
└── views.py
アプリインストールの設定を追加
test_project/settings.py
INSTALLED_APPS = [
039;django.contrib.admin039;,
039;django.contrib.auth039;,
039;django.contrib.contenttypes039;,
039;django.contrib.sessions039;,
039;django.contrib.messages039;,
039;django.contrib.staticfiles039;,
039;testapp039;,
]
作成したtestappアプリのviewへアクセスするURL Pathを作成
import testapp.views as test_view
urlpatterns = [
path(039;test/039;, test_view.View.as_view())
]
GET されたら、ただテンプレートを表示。
POST されたら、POSTされた値を表示するだけの、view
testapp/views.py
from django.shortcuts import render
# Create your views here.
from django.shortcuts import render, redirect, get_object_or_404
from django.views.generic import TemplateView
from testapp.models import *
import logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
class View(TemplateView):
template_name = "test.html"
def get(self, request):
context = {}
return render(self.request, self.template_name, context)
def post(self, request):
context = {
039;action039;: request.POST.get(039;action039;),
039;name1039;: request.POST.get(039;name1039;),
039;name2039;: request.POST.get(039;name2039;),
}
logger.info(request.POST)
return render(self.request, self.template_name, context)
作成したアプリフォルダの下に、templatesフォルダを作成し、view.pyで記述したtest.htmlを用意
testapp/templates/test.html
Hello World!
<br>
{% if action %}
action = {{ action }}
<h1>
{{ action }} が押されました。
</h1>
name1 = {{name1}}<br>
name2 = {{name2}}
{% endif %}
<form method=039;post039; action=039;/test/039;>
{% csrf_token %}
<input type=039;hidden039; name=039;name1039; value=039;value1039;>
<input type=039;hidden039; name=039;name2039; value=039;value2039;>
<button type=039;submit039; name=039;action039; value=039;Button1039;>Button1</button>
<button type=039;submit039; name=039;action039; value=039;Button2039;>Button2</button>
</form>