sudo vim /etc/environment
在PATH =之后加上':/usr/local/lib/python2.7/dist-packages/django/bin'
$ django-admin.py startproject my_blog
$ cd my_blog
$ python manage.py startapp article
python manage.py <command> [options] #Django Command
python manange.py -h幫助文檔
django-admin.py startproject my_blog #創(chuàng)建項(xiàng)目
python manage.py startapp article #創(chuàng)建app
python manage.py runserver localhost:9000 #啟動(dòng)Django中的開發(fā)服務(wù)器
二埋心、Models
1. Django Model
- 每一個(gè)Django Model都繼承自django.db.models.Model
- 在Model當(dāng)中每一個(gè)屬性attribute都代表一個(gè)database field
- 通過Django Model API可以執(zhí)行數(shù)據(jù)庫(kù)的增刪改查, 而不需要寫一些數(shù)據(jù) 庫(kù)的查詢語(yǔ)
2.設(shè)置數(shù)據(jù)庫(kù)
- Django項(xiàng)目建成后, 默認(rèn)設(shè)置了使用SQLite數(shù)據(jù)庫(kù), 在 my_blog/my_blog/settings.py 中可以查看和修改數(shù)據(jù)庫(kù)設(shè)置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
3.創(chuàng)建models
在my_blog/article/models.py下編寫如下程序:
from django.db import models
class Article(models.Model) :
title = models.CharField(max_length = 100)
category = models.CharField(max_length = 50, blank = True)
date_time = models.DateTimeField(auto_now_add = True)
content = models.TextField(blank = True, null = True)
def str(self) :
return self.title
class Meta: #按時(shí)間下降排序
ordering = ['-date_time']
###4.同步數(shù)據(jù)庫(kù)
>python manage.py migrate #命令行運(yùn)行該命令 提示數(shù)據(jù)庫(kù)有改動(dòng)末誓,需要執(zhí)行 python manage.py makemigrations 來是數(shù)據(jù)庫(kù)生效复罐,然后在執(zhí)行python manage.py migrate
###5.Django Shell
>Django的 CURD 操作。
執(zhí)行 python manage.py shell 進(jìn)入命令行操作。
Article.objects.create(title = 'Hello World', category = 'Python', content = 'Let us add a database item')
Article.objects.all()
Article.objects.get(id = 1)
Article.objects.filter(title='Django Blog Study')
Article.objects.order_by("title")
Article.objects.filter(title__contains='Django')[0]
等等
##三. Admin
###1.Admin簡(jiǎn)介
>Django有一個(gè)優(yōu)秀的特性, 內(nèi)置了Django admin后臺(tái)管理界面, 方便管理者進(jìn)行添加和刪除網(wǎng)站的內(nèi)容.
可以管理該project下的項(xiàng)目漱抓。
###2.設(shè)置Admin
>新建的項(xiàng)目系統(tǒng)已經(jīng)為我們?cè)O(shè)置好了后臺(tái)管理功能
可以在my_blog/my_blog/settings.py中查看
INSTALLED_APPS = (
'django.contrib.admin', #默認(rèn)添加后臺(tái)管理功能
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'article'
)
>同時(shí)也已經(jīng)添加了進(jìn)入后臺(tái)管理的url, 可以在my_blog/my_blog/urls.py中查看
-- coding: utf-8 --
from django.conf.urls import url
from django.contrib import admin
urlpatterns = [
# Examples:
# url(r'^$', 'my_blog.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', admin.site.urls), #可以使用設(shè)置好的url進(jìn)入網(wǎng)站后臺(tái)
]
###3.創(chuàng)建超級(jí)用戶
>使用如下命令賬號(hào)創(chuàng)建超級(jí)用戶(如果使用了python manage.py syncdb會(huì)要求你創(chuàng)建一個(gè)超級(jí)用戶, 該命令已經(jīng)過時(shí), 不再推薦使用)
python manage.py createsuperuser
Username (leave blank to use 'test'): root
Email address:
Password:
Password (again):
Superuser created successfully.
輸入用戶名, 郵箱, 密碼就能夠創(chuàng)建一個(gè)超級(jí)用戶
##四. Views和URL
###1.網(wǎng)頁(yè)程序的邏輯
>request進(jìn)來->從服務(wù)器獲取數(shù)據(jù)->處理數(shù)據(jù)->把網(wǎng)頁(yè)呈現(xiàn)出來
url設(shè)置相當(dāng)于客戶端向服務(wù)器發(fā)出request請(qǐng)求的入口, 并用來指明要調(diào)用的程序邏輯
views用來處理程序邏輯, 然后呈現(xiàn)到template(一般為GET方法, POST方法略有不同)
template一般為html+CSS的形式, 主要是呈現(xiàn)給用戶的表現(xiàn)形式
###2.簡(jiǎn)單Django Views和URL
>Django中views里面的代碼就是一個(gè)一個(gè)函數(shù)邏輯, 處理客戶端(瀏覽器)發(fā)送的HTTPRequest, 然后返回HTTPResponse,
那么開始在my_blog/article/views.py中編寫簡(jiǎn)單的邏輯
現(xiàn)在你的views.py應(yīng)該是這樣
from django.shortcuts import render
from django.http import HttpResponse
Create your views here.
def home(request):
return HttpResponse("Hello World, Django")
>那么如何使這個(gè)邏輯在http請(qǐng)求進(jìn)入時(shí), 被調(diào)用呢, 這里需要在my_blog/my_blog/urls.py中進(jìn)行url設(shè)置
from django.conf.urls import url
from django.contrib import admin
from article import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^$', views.home),
]
> url()函數(shù)有四個(gè)參數(shù), 兩個(gè)是必須的:regex和view, 兩個(gè)可選的:kwargs和name
>>* regex是regular expression的簡(jiǎn)寫,這是字符串中的模式匹配的一種語(yǔ)法, Django 將請(qǐng)求的URL從上至下依次匹配列表中的正則表達(dá)式扒接,直到匹配到一個(gè)為止。
* view當(dāng) Django匹配了一個(gè)正則表達(dá)式就會(huì)調(diào)用指定的view邏輯, 上面代碼中會(huì)調(diào)用article/views.py中的home函數(shù)
* kwargs任意關(guān)鍵字參數(shù)可傳一個(gè)字典至目標(biāo)view name命名你的 URL, 使url在 Django 的其他地方使用, 特別是在模板中