wfastcgi-enable.exeを実行すると”failed to create process”

IISでPythonアプリを動かすため、wfastcgiをpipでインストールし、wfastcgi-enable.exeをたたいたときに

failed to create process  のエラー発生。

いろいろ調べた所、wfastcgi-enable-script.pyのほうの一行目を
#!c:\program files (x86)\python35\python.exe

#!”c:\program files (x86)\python35\python.exe”  に変更した所、うまくいった。pythonでは、program files のようのフォルダ名のなかに空白が入っていると、今回のようにうまくいかないモジュールがある模様。Pythonは無難にC:\pyhon3.6.1のように空白文字を入れないようなディレクトリパスでインストしておくほうがよい。

formにBootstrapのスタイルを適用

 

Bootstrapのフォームスタイルを適用するには、class属性にform-controlと定義する必要がある。Djangoのフォームに、このform-controlを仕込むには、
widget.attrsを使い、下記のように定義する。

例えばforms.pyにて下記のように定義

すると、HTMLタグに

 
とclass属性がちゃんと定義される。

Django:フィールドのアップデートのやりかた

Domainテーブルにdomain_id列と、data_alert_flag列があるとする、
特定のdomain_idを保有している行のみを抽出し、その行のdata_alert_flag列の値を更新するには、

パターン1:

※.save()を実行する必要なし。.updateを実行すると保存される。

パターン2:

 

Model:choiceを定義するときの設定間違い

RANK_CHOICES = (
(1, ‘Principal’),
(2, ‘Vice’),
)

だとデータ登録時に下記のエラーが発生する。

return int(value)
ValueError: invalid literal for int() with base 10: ”

ただしくは、下記のように二要素のタプルにてクォートで囲む。

RANK_CHOICES = (
(‘1’, ‘Principal’),
(‘2’, ‘Vice’),
)

admin_rank = models.CharField(max_length=50,choices=RANK_CHOICES, blank=False,default=”)

Django

仕組み
ユーザがURLを叩いた時=>urls.pyで該当のビューが呼び出され=>
・リクエストされたURLとビューのマッピング定義は、urls.pyに記載
・よびだすHTML文書(template)とフィールドの定義は、views.pyに記載
views.pyに定義された、
 ビュー関 数の第一引数には HttpRequest が、それ以降の引 数には正規表現でキャプチャした値が渡され、
URL 中の値を取り出すには、正規表現にて、単に丸括弧で囲むだけです。
 
例えば、 (r’^articles/(\d{4})/(\d{2})/$’, ‘news.views.month_archive’)と定義されており、合致するリクエスト、/articles/2005/03/ が来た場合、
ビュー関数、news.views.month_archive(request, '2005', '03') を 呼び出します。第二引数、第三引数に2005,03がそれぞれ入ります。
 
^ ・・・行頭にマッチ。\d・・・0-9の数字。{m}・・・前にある RE の m 回の正確なコピーとマッチ。\d{4}は4桁の0-9の数字。$・・・行尾をさす。
 
(?P<name>pattern) ・・・名前つきの 正規表現グループで URL から情報を取り出し、ビュー の キーワード引数 に渡す
 
・templateはbase.htmlやそのたhtmlファイルに記載
・データベースに格納するテーブル、フィールドの定義は、models.pyに記載
urls.pyのurl関数は、正規表現を持ちいる。
正規表現例
 ‘^’   文字列の先頭とマッチします
 ‘+’  直前にある RE に作用して、RE を、1 回以上繰り返したものにマッチさせるようにします。例えば ab+ は ‘a’ に一つ以上の ‘b’ が続いたものにマッチし、’a’ 単体にはマッチしません
 ‘$’  文字列の末尾、あるいは文字列の末尾の改行の直前にマッチします。例えば、foo は ‘foo’ と ‘foobar’ の両方にマッチします。一方、正規表現 foo$ は ‘foo’ だけとマッチします。興味深いことに、’foo1\nfoo2\n’ を foo.$ で検索した場合、通常のモードでは ‘foo2’ だけにマッチし、MULTILINE モードでは ‘foo1’ にもマッチします。$ だけで ‘foo\n’ を検索した場合、2箇所 (内容は空) でマッチします: 1つは、改行の直前で、もう1つは、文字列の最後です。
 ¥d  任意の Unicode 10進数 (Unicode 文字カテゴリ [Nd]) とマッチします
 (?P<name>…)  (?P<name>…) はグループに名前 name を付けます。
参考:第 4 回 正規表現とジェネレータ http://www.geocities.jp/m_hiroi/light/python04.html
6.2. re — 正規表現操作 http://docs.python.jp/3.4/library/re.html
 Django用語         意味
 テンプレート Django ではテンプレートという仕組みによって、HTML によるビューをロジックから分離している。Webブラウザで表示させるhtmlのことをテンプレートという
 マイグレーション Djangoで内部的に利用しているデータベースのスキーマを変更することをMigrationという

Migrationって? http://blog.hoerin.com/category/python/
 モデル モデルとはサイトを構成するデータの、唯一絶対的なデータソースを指します。 モデルには、保存したいデータを表すデータフィールドと、データのビヘイビアを 定義します。通常、一つのモデルは一つのデータベーステーブルに対応しています。
 URLConf  URL 構造を定義す るには、 URLconf と呼ばれる Python モジュールを作成します。 Django は URLconf を使ってどの URL をどの Python コードに関連づけるかを決めています
 URL パターン (単純な正規表現) から Python のコールバック関数 (自作のビュー) へのマッピングが入っている

URLConf(urls.py)の一例

 テンプレート  Djangoはテンプレートファイル(html)を呼び出し、WEB画面のデザインのテンプレートとして表示させる
 Django テンプレート言語  テンプレートの表記法。Pythonとは違った文法。

コンテキスト (context) はテンプレートに渡される「変数名」から「変数の値」 へのマッピング.

 IDLE  PYTHONインストすると自動で入るコマンドインタフェース。C:\Python34\Lib\idlelibにidle.batが含まれており、それで起動する。
 
 文法          解説
 __str__(self):  データベースから返される文字列は全て Unicode 文字列であり、メソッドにこの__str__を定義しておくと、戻り値をUnicodeに変換して返してくれる。この定義がないと、具体的な格納値がDjango adminなどから確認できない。
   
I
Djangoの始め方
1.projectの作成 ↓たとえばmysiteというプロジェクトを作る

django-admin.py startproject mysite

上記コマンドを実行したカレントフォルダにmysiteフォルダができる
↓このようなファイル構成
mysite
|
|   manage.py
|
\—mysite
        settings.py
        urls.py
        wsgi.py
        __init__.py
2.データベースのセットアップ ↓データベースの設定は、settings.py にありますが、標準では、SQlite3を使うよう設定済

python manage.py migrate

3.スーパーユーザーを作成
python manage.py createsuperuser
C:\Python34\mysite>python manage.py createsuperuser
Username (leave blank to use ‘hide’): admin
Email address:
Password:
Password (again):
Superuser created successfully.
4.開発サーバの起動

python manage.py runserver

5.アプリケーションの作成

アプリケーションは、プロジェクトを構成する機能の単位で、場合によっては再利用の対象とできる単位

python manage.py startapp cms

6.データベースに定義したいデータ モデルを、cms/models.py に定義
 
7.モデルを有効にする
cms アプリケーションをインストールしたことを、プロジェクトに教えてあげる必要があります。/settings.py の INSTALLED_APPS の最後に cms を追加。
 
8.言語とタイムゾーンを日本にします
9.以下のコマンドで、models.py の変更を拾って、マイグレーションファイルを作成

python manage.py makemigrations cms

10.このマイグレートファイルが、どのような SQL になるか、以下のコマンドで確認

python manage.py sqlmigrate cms 0001

11.まだデータベースに反映していないマイグレートファイルを、以下のコマンドでデータベースに反映

python manage.py migrate

12.管理サイトの有効化
管理サイトというものがあって、ここからマスターメンテナンス的なデータ投入がすべてできてしまいます。
 1python manage.py runserver で開発用サーバを起動します。
 2http://127.0.0.1:8000/admin/ にブラウザでアクセスします。
 3初回の $ python manage.py createsuperuser で初期化したスーパーユーザー admin/admin でログインします。
13 cms モデルを admin 上で編集できるようにする
cms/admin.py に、管理サイトへ表示したいモデルを追加
14 データの追加、修正、削除を確認

管理サイトの一覧を見た時、models.py の

で設定したものが、レコード名として見えています。

15もう少しレコードの項目全体が見えるよう、cms/admin.py を修正

モデルに追加したテーブルの一覧、登録、修正、削除が簡単にできました
 
Bootstrapの導入
Bootstrap で必要な jQuery を含めて、以下からダウンロード
ダウンロードしたファイルを、mybook プロジェクト ディレクトリの下に static というディレクトリを作って、以下のように配置
この static というディレクトリは、mybook/settings.py の STATIC_URL で指定されたディレクトリ
ここを探してくれるよう、mybook/settings.py の最後に、STATICFILES_DIRS を追加
 

django-bootstrap-form

一覧系HTMLは、Bootstrapで必要なclassを手書きして、登録/修正のフォーム系HTMLは django-bootstrap-form という Python モジュールを使います。

 
mybook/settings.py の INSTALLED_APPS に ‘bootstrapform’ を追加
 

ビューをざっと作る

一覧、登録、修正、削除のファンクションが必要なので、`cms/views.py’ にひな形を作る

URL スキームの設計

cms/urls.py というファイルは存在しないので、新しく作る。この中で、URLと、ビューのファンクションの紐付けを行う
============================

Djangoのバージョン確認
C:\Python34>pip freeze|find “Django”
Django==1.8.3

メールの送信

1.setting.pyに以下を記載
EMAIL_HOST=’SMTPサーバ名’
EMAIL_PORT = 25
EMAIL_HOST_USER = ”
EMAIL_HOST_PASSWORD = ”
EMAIL_USE_TLS = False
2.views.pyに以下を記載
from django.core.mail import EmailMessage
def <ここにview名>(request):
    email = EmailMessage(‘Hello’, ‘World’, to=[‘root@test.com’])
    email.send()
viewが呼ばれた瞬間にメールが対象のSMTPサーバ宛に飛ぶ

タイトルの通り、同一フォーム内でクリックしたボタンによって異なる処理を行いたい場合は以下のように書きます。

hoge.html

views.py

Djangoで使える開発用SMTPサーバ

メール挙動の確認のために、開発用SMTPサーバが用意されている

以下を一行で実行すれば、1025番でSMTPサーバが立ち上がる。

Djangoのsettings.pyに独自設定を定義する

このエントリーをブックマークに追加 このエントリーを含むはてなブックマーク
Djangoの設定はsettings.pyにいろいろ書かれています。
なので自分が作成するアプリケーション用の設定も同じく書いておきたいわけです。
それは、
http://djangoproject.jp/doc/ja/1.0/topics/settings.html#topics-settings
にちゃんと書いてあるので、そこを見ればOKです。

要約すると
settings.pyには、普通にオリジナルの設定を他の既存のパラメータと同様な感じで定義できます。
例えば、
MY_CONF = ‘test conf’
とか普通に書きます。

使うときですが、利用するファイルで
from django.conf import settings
として、
val = settings.MY_CONF
で利用できます。

ユーザ認証

必要な設定:
 
■settings.py

・settings.pyのINSTALLED_APPSにデフォルトでは次のアプリが含まれているはずなので、有無を確認

 ’django.contrib.auth’
‘django.contrib.contenttypes’
・settings.pyの、LOGIN_URLにて、ログイン画面を表示するURLを定義。
 LOGIN_REDIRECT_URLにて、ログイン後のリダイレクト先を指定。
 
■ログイン、ログアウトのHTMLtemplateを用意。ログイン用のtemplateは、ユーザー名とパスワード入力を求める画面となる。
 
djangoにはログイン・ログアウト用のviewがデフォルトで用意されている。それをurls.pyで指定
 
 
■login_requiredデコレータを使えば,ページの閲覧をログイン済みのユーザだけに制限することが出来る.
login_req_requiredを使わないと、if not request.user.is_authenticated():と記述しないといけないので手間。

Django tuttorial

Django公式サイトのチュートリアル https://docs.djangoproject.com/en/1.8/intro/tutorial01/

以下を作成する。
・ユーザが投票できるsite
・管理者がデータをCRUIDできる管理画面
・プロジェクト作成
django-admin startproject  polltutorial
↓生成されるもの
polltutorial/     <==プロジェクトフォルダ
    manage.py   <==管理用コマンドラインユーテリティ
    mysite/
        __init__.py  <==空ファイル。このファイルがあることで、PythonがこのフォルダがPythonパッケージであると認識する。
        settings.py  <==setting/config用ファイル
        urls.py     <==URL宣言
        wsgi.py
・models.pyでモデルを作成。
作成するモデルは、django.db.models.Model のサブクラスとなる。models.pyで定義するクラスは、表に相当し、クラス内で定義するフィールドが表の列に相当。
 
外部キー
参照制約において定義され、他の列との値の依存関係を持つ。例えば、FOREIGN KEY(A) REFERENCES TABLE1(B)と記述した場合、外部キー列Aの値は、TABLE1の列Bが持つ値に含まれるかNULL値でなければならない。
外部キーが参照する列は、主キー(Primary Key)か代理キー(Alternate Key)でなければならず、同一テーブル内の列でも、他のテーブルの列のどちらも指定可能である。なお、同一テーブル内の列を参照することを自己参照と呼ぶ。

Django form

FormのフィールドのHTMLテンプレートにおける表現方法
 
{{ form.as_p }}・・・・forms.pyで定義した各フィールドとラベルをパラグラフ (<p>) タグ で囲って出力します
{{ form.as_table }}・・・各フィールドがテーブルの各行になるように出力で きます (自分で <table> タグで囲む必要があります)。
↓このように name=”XXXXX”のところに、Formフィールド名を指定すると、当該フィールドとして認識され、画面インプットの値が
当該フィールドの値として入る
<p><label for=”id_subject”>Subject:</label>
<input id=”id_subject” type=”text” name=”subject” maxlength=”100″ /></p>
 
また、↓このような書き方もHTMLテンプレート上にできる
{{form.subject}}  <==forms.pyで定義したsubjectフィールド

Djangoの学習サイト

djangoboook・・・Djangoを始めるにあたってとてもわかりやすく解説しているサイト。ただし英語である。何故わかりやすいかというと、なぜそうするのかという理由を初学者にも分かる言葉で書かれているから。Django用語の解説も丁寧である。本家のチューとリアルをやるよりもわかりやすい。