サンプルを見る
📖 この記事のゴール
目標
What is | This is |
---|---|
この連載の目的 | 連続名(Consecutive name)ツール を作る |
この記事の目標 | いきなり 連続名(Consecutive name)ツール を作るのは難しいから、まずダミーデータのWebページを開設する |
情報
👇 この記事はレッスン編を読み終えた人を対象とする
What is | This is |
---|---|
レッスン編 | 📖 [O1o1o0] DjangoとDockerでゲーム対局サーバーを作ろう! |
👇 Step の変な数字の説明
📖 電脳向量表記
始める前に
👇 まず、継続(Continue)と 連続(Consecutive) の違いを説明する
- 継続:
1
→1
→1
→1
- 連続:
1
→2
→3
→4
👇 連続名(Consecutive name)の分かりやすい例は以下を参考
📖 出世魚ってどんな魚??
📖 世界コンピュータ将棋選手権のプログラム別順位の推移
👇 連続名(Consecutive name)の必要性は、主に 以下のことを決める需要からある
- 何回出場表彰というカウントを引き継ぐチーム
- 前年の順位のシード権を引き継ぐチーム
- 新人賞の候補となるチーム
👇 以下は「連続」。前と後ろで違うがつながっている。何と何が連続しているか判定する方法は人為的だ。このツールは記録と表示のみ行う
- 去年 Apple という名前のチームが 今年は Banana という名前で出場している
- 去年 Cherry という名前のチームが、今年は Durian と Eggfruit という名前で出場している
- 去年 Fig と Grape という名前のチームが、今年は合体して Hernandia という名前で出場している
👇 以下は「継続」。前と後ろで違わずつながっている。何が継続しているか判定する方法は人為的だ。このツールは記録と表示のみ行う
- 去年 Icaco という名前のチームが 今年も Icaco という名前で出場している
- 数年ぶりに Jujube という名前のチームが出場している(途中で名前を変えて出場していたかどうかは分からない)
手順
Step [OAAA1001o2o0g1o0] Dockerコンテナの起動
(していなければ) Docker コンテナを起動しておいてほしい
# docker-compose.yml ファイルを置いてあるディレクトリーへ移動してほしい
cd src1
# Docker コンテナ起動
docker-compose up
Step [OAAA1001o2o0g2o0] フォルダー作成 - apps1/consecutive_name_vol1o0 フォルダー
👇 以下のフォルダーを新規作成してほしい
└── 📂 src1
└── 📂 apps1 # 複数のアプリケーションを入れるフォルダー
└── 📂 consecutive_name_vol1o0 # アプリケーション
Step [OAAA1001o2o0g3o0] アプリケーション作成
Dockerコンテナ を起動しているターミナルとは別のターミナルをもう1つ開き、
👇 以下のコマンドを打鍵してほしい
# docker-compose.yml ファイルを置いてあるディレクトリーへ移動してほしい
cd src1
# アプリケーション新規作成
docker-compose run --rm web python manage.py startapp consecutive_name_vol1o0 ./apps1/consecutive_name_vol1o0 --settings=project1.settings
# ----------------------- ------------------------------- -----------------
# 1 2 3
# 1. 任意のDjangoアプリケーション名
# 2. アプリケーション フォルダーへのパス
# 3. `src1/project1/settings.py` 設定ファイルに従う
# -----------------
👇 以下のようなディレクトリー、ファイルが自動生成される
└── 📂 src1
└── 📂 apps1
└── 📂 consecutive_name_vol1o0 # アプリケーション
👉 ├── 📂 migrations
👉 │ └── 📄 __init__.py
👉 ├── 📄 __init__.py
👉 ├── 📄 admin.py
👉 ├── 📄 apps.py
👉 ├── 📄 models.py
👉 ├── 📄 tests.py
👉 └── 📄 views.py
Step [OAAA1001o2o0g4o0] 今回使わないファイルの削除
👇 以下のファイルを削除してほしい
└── 📂 src1
└── 📂 apps1
└── 📂 consecutive_name_vol1o0 # アプリケーション名
├── 📂 migrations
│ └── 📄 __init__.py
├── 📄 __init__.py
├── 📄 admin.py
├── 📄 apps.py
👉 ├── 📄 models.py
├── 📄 tests.py
👉 └── 📄 views.py
Step [OAAA1001o2o0g5o0] アプリケーション設定変更 - apps.py
👇 以下のファイルを編集してほしい
└── 📂 src1
└── 📂 apps1
└── 📂 consecutive_name_vol1o0 # アプリケーション
├── 📂 migrations
│ └── 📄 __init__.py
├── 📄 __init__.py
├── 📄 admin.py
👉 ├── 📄 apps.py
└── 📄 tests.py
from django.apps import AppConfig
class NameOfConsecutiveVol1O0Config(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
# * 変更前
# name = 'consecutive_name_vol1o0'
# * [OAAA1001o2o0g5o0] 変更後
name = 'apps1.consecutive_name_vol1o0'
# -----------------------------
# 1
# 1. `src1/apps1/consecutive_name_vol1o0/apps.py`
# -----------------------------
Step [OAAA1001o2o0g6o0] アプリケーション登録 - settings.py ファイル
👇 以下の既存ファイルを編集してほしい
└── 📂 src1
├── 📂 apps1
│ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ ├── 📂 migrations
│ │ └── 📄 __init__.py
│ ├── 📄 __init__.py
│ ├── 📄 admin.py
│ ├── 📄 apps.py
│ └── 📄 tests.py
└── 📂 project1
👉 └── 📄 settings.py
# ...略...
INSTALLED_APPS = [
# ...略...
# あなたが追加したアプリケーション
# ...略...
# [OAAA1001o2o0g6o0] 連続名1.0巻
'apps1.consecutive_name_vol1o0',
# ...略...
# Djangoの標準アプリケーション
# ...略...
]
# ...略...
Step [OAAA1001o2o0g7o0] テンプレートフォルダー指定 - settings.py ファイル
👇 以下の既存ファイルを編集してほしい
└── 📂 src1
├── 📂 apps1
│ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ ├── 📂 migrations
│ │ └── 📄 __init__.py
│ ├── 📄 __init__.py
│ ├── 📄 admin.py
│ ├── 📄 apps.py
│ └── 📄 tests.py
└── 📂 project1
👉 └── 📄 settings.py
👇 変更するのは TEMPLATES[0]["DIRS"]
変数
TEMPLATES = [
{
# ...略... 'BACKEND'
'DIRS': [
# ...略...
# [OAAA1001o2o0g7o0] 連続名1.0巻
os.path.join(BASE_DIR, 'apps1/consecutive_name_vol1o0/templates'),
# ---------------------------------------
# 10
# Example: `/src1/apps1/consecutive_name_vol1o0/templates/consecutive_name_vol1o0/board/ver0o1o0.html`
# ----------------------- ------------------------
# 11 2
# -----------------------------
# 10
# 10. テンプレート ディレクトリーへのパス
# 11. アプリケーション
# 2. まるで `http://example.com/consecutive_name_vol1o0` という素材フォルダーがあるかのように扱われる
# -------------------------
],
# ...略... 'APP_DIRS' や 'OPTIONS'
},
]
Step [OAAA1001o2o0g8o0] スモークテスト用データ作成 - smoke_test/ver1o0.json ファイル
👇 以下のファイルを新規作成してほしい
└── 📂 src1
├── 📂 apps1
│ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ ├── 📂 migrations
│ │ └── 📄 __init__.py
│ ├── 📂 static
│ │ └── 📂 consecutive_name_vol1o0 # アプリケーションと同名
│ │ └── 📂 data
│ │ └── 📂 smoke_test
👉 │ │ └── 📄 ver1o0.json
│ ├── 📄 __init__.py
│ ├── 📄 admin.py
│ ├── 📄 apps.py
│ └── 📄 tests.py
└── 📂 project1
└── 📄 settings.py
{
"headers": [
{
"text": "2020春",
"align": "start",
"sortable": false,
"value": "event2020spr"
},
{ "text": "2020冬", "value": "event2020wtr" },
{ "text": "2021春", "value": "event2021spr" },
{ "text": "2021冬", "value": "event2021wtr" },
{ "text": "2022春", "value": "event2022spr" },
{ "text": "2022冬", "value": "event2022wtr" }
],
"bodies": [
{
"event2020spr": "Apple",
"event2020wtr": "Apple",
"event2021spr": "Apple",
"event2021wtr": "Banana",
"event2022spr": "Banana",
"event2022wtr": "Apple"
},
{
"event2020spr": "Cherry",
"event2020wtr": "Cherry",
"event2021spr": "Cherry",
"event2021wtr": "Durian",
"event2022spr": "Durian",
"event2022wtr": "Durian"
},
{
"event2020spr": "Cherry",
"event2020wtr": "Cherry",
"event2021spr": "Cherry",
"event2021wtr": "Eggfruit",
"event2022spr": "Eggfruit",
"event2022wtr": "Eggfruit"
},
{
"event2020spr": "Fig",
"event2020wtr": "Fig",
"event2021spr": "Fig",
"event2021wtr": "Fig",
"event2022spr": "Hernandia",
"event2022wtr": "Hernandia"
},
{
"event2020spr": "Grape",
"event2020wtr": "Grape",
"event2021spr": "Grape",
"event2021wtr": "Grape",
"event2022spr": "Hernandia",
"event2022wtr": "Hernandia"
}
]
}
Step [OAAA1001o2o0g9o0] 画面作成 - settings.py ファイル
👇 以下のファイルを新規作成してほしい
└── 📂 src1
├── 📂 apps1
│ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ ├── 📂 migrations
│ │ └── 📄 __init__.py
│ ├── 📂 static
│ │ └── 📂 consecutive_name_vol1o0 # アプリケーションと同名
│ │ └── 📂 data
│ │ └── 📂 smoke_test
│ │ └── 📄 ver1o0.json
│ ├── 📂 templates
│ │ └── 📂 consecutive_name_vol1o0
│ │ └── 📂 data_table
│ │ └── 📄 ver1o0.html
│ ├── 📄 __init__.py
│ ├── 📄 admin.py
│ ├── 📄 apps.py
│ └── 📄 tests.py
└── 📂 project1
└── 📄 settings.py
<!-- BOF [OAAA1001o2o0g9o0] -->
{% load static %} {# 👈あとで static "URL" を使うので load static します #}
<!DOCTYPE html>
<!-- See also: https://vuetifyjs.com/en/components/data-tables/#dense -->
<html lang="ja">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui" />
<link href="https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900" rel="stylesheet" />
<link href="https://cdn.jsdelivr.net/npm/@mdi/font@6.x/css/materialdesignicons.min.css" rel="stylesheet" />
<!-- Vuetify -->
<link href="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.min.css" rel="stylesheet" />
<link rel="shortcut icon" type="image/png" href="{% static 'favicon.ico' %}" />
<!-- ===================
1
1. Example: `http://example.com/static/favicon.ico`
==================
-->
<title>連続名ツール</title>
</head>
<body>
<div id="app">
<v-app>
<v-main>
<v-container>
<v-data-table :headers="headers" :items="bodies" :items-per-page="5" class="elevation-1"></v-data-table>
</v-container>
</v-main>
</v-app>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2.x/dist/vue.js"></script>
<script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>
<script>
// "dj_" は 「Djangoがレンダーに埋め込む変数」 の目印
var dataTableJsObject = JSON.parse("{{ dj_dataTableJson|escapejs }}");
new Vue({
el: "#app",
vuetify: new Vuetify(),
data: dataTableJsObject,
});
</script>
</body>
</html>
<!-- EOF [OAAA1001o2o0g9o0] -->
Step [OAAA1001o2o0g10o0] ビュー作成 - board/ver1o0 フォルダー
👇 以下のファイルを新規作成してほしい
└── 📂 src1
├── 📂 apps1
│ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ ├── 📂 migrations
│ │ └── 📄 __init__.py
│ ├── 📂 static
│ │ └── 📂 consecutive_name_vol1o0 # アプリケーションと同名
│ │ └── 📂 data
│ │ └── 📂 smoke_test
│ │ └── 📄 ver1o0.json
│ ├── 📂 templates
│ │ └── 📂 consecutive_name_vol1o0
│ │ └── 📂 data_table
│ │ └── 📄 ver1o0.html
│ ├── 📂 views
│ │ └── 📂 data_table
│ │ └── 📂 ver1o0
👉 │ │ └── 📄 __init__.py
│ ├── 📄 __init__.py
│ ├── 📄 admin.py
│ ├── 📄 apps.py
│ └── 📄 tests.py
└── 📂 project1
└── 📄 settings.py
# BOF [OAAA1001o2o0g10o0]
import json
from django.shortcuts import render
class DataTableView():
"""[OAAA1001o2o0g10o0] データテーブル"""
@staticmethod
def render(request):
"""[OAAA1001o2o0g10o0] 描画"""
# Template path
data_table_tp = 'consecutive_name_vol1o0/data_table/ver1o0.html'
# ----------------------------------------------
# 1
# 1. `src1/apps1/consecutive_name_vol1o0/templates/consecutive_name_vol1o0/data_table/ver1o0.html` を取得
# ----------------------------------------------
with open('apps1/consecutive_name_vol1o0/static/consecutive_name_vol1o0/data/smoke_test/ver1o0.json', mode='r', encoding='utf-8') as f:
# ----------------------------------------------------------------------------------------
# 1
# 1. `src1/apps1/consecutive_name_vol1o0/static/consecutive_name_vol1o0/data/smoke_test/ver1o0.json` を取得
# ----------------------------------------------------------------------------------------
jsObject = json.load(f)
context = {
# "dj_" は 「Djangoがレンダーに埋め込む変数」 の目印
'dj_dataTableJson': json.dumps(jsObject)
}
return render(request, data_table_tp, context)
# EOF [OAAA1001o2o0g10o0]
Step [OAAA1001o2o0g11o0] ルート編集 - urls.csv ファイル
👇 以下の既存ファイルの末尾に追記してほしい
├── 📂 src1
│ ├── 📂 apps1
│ │ └── 📂 consecutive_name_vol1o0 # アプリケーション
│ │ ├── 📂 migrations
│ │ │ └── 📄 __init__.py
│ │ ├── 📂 static
│ │ │ └── 📂 consecutive_name_vol1o0 # アプリケーションと同名
│ │ │ └── 📂 data
│ │ │ └── 📂 smoke_test
│ │ │ └── 📄 ver1o0.json
│ │ ├── 📂 templates
│ │ │ └── 📂 consecutive_name_vol1o0
│ │ │ └── 📂 data_table
│ │ │ └── 📄 ver1o0.html
│ │ ├── 📂 views
│ │ │ └── 📂 data_table
│ │ │ └── 📂 ver1o0
│ │ │ └── 📄 __init__.py
│ │ ├── 📄 __init__.py
│ │ ├── 📄 admin.py
│ │ ├── 📄 apps.py
│ │ └── 📄 tests.py
│ └── 📂 project1
│ └── 📄 settings.py
└── 📂 src1_meta
└── 📂 data
👉 └── 📄 urls.csv
...略... file,path,name,comment,module,class,alias,method
...略...
../src1/project1/urls_consecutive_name_vol1o0_autogen.py,consecutive_name/vol1.0/data-table/ver0.1/,,"[OAAA1001o2o0g11o0] ライフゲーム1.0巻 盤0.1版",apps1.consecutive_name_vol1o0.views.data_table.ver1o0,DataTableView,ConsecutiveName1o0DataTableView1o0,render
Step [OAAA1001o2o0g11o0] ルート編集 - コマンド打鍵
👇 以下のコマンドをコピーして、ターミナルに貼り付けてほしい
cd ../src1_meta
python -m scripts.auto_generators.urls
確認がでてきて、良ければ y
👇 以下のコマンドをコピーして、ターミナルに貼り付けてほしい
cd ../src1
docker-compose restart
- ディレクトリーは、がんばって移動してほしい
- スクリプトについて See also: O3o2o_1o0g2o0
- 設定ファイルを変更したら、サーバーの再起動が必要
Step [OA13o1o0g7o0] Web画面へアクセス
📖 http://localhost:8000/consecutive_name/vol1.0/data-table/ver0.1/
次の記事
📖 DjangoとDocker自由課題[OAAA1001o2o1o0] 催事のマスターデータを作ろう!
以上