Python采用Django開發(fā)自己的博客系統(tǒng)
好久之前就想做一下自己的博客系統(tǒng)了,但是在網(wǎng)上查了查好像是需要會一些Node.js的相關(guān)知識,而且還要安裝辣么多的庫什么的,就不想碰了。但是我遇到了Django這么一款神器,沒想到我的博客系統(tǒng)就這么建立起來了。雖然是最基礎的類型。但是也算是成功了,這篇博客比較適合對Django有了一定了解的童鞋,如果是新手的話,建議先看一下django的基礎知識點再來做實驗,這樣效率更高!
好了,話不多說,開始吧。
搭建框架
•創(chuàng)建項目及應用
搭建框架的意思,就是安裝Django以及做好相關(guān)的配置。因為我是在PyCharm下進行創(chuàng)建的,所以工具代替我做了很多事情。但是底層也無非是下面幾行代碼:
創(chuàng)建一個Django項目,名為MyDjango
django-admin startproject MyDjango
創(chuàng)建一個Django應用,名為MyBlog。這里應該注意的是應用隸屬于項目的子集。通俗的來說應用文件夾是作為項目文件夾的子集而存在的。
django-admin startapp MyBlog
•創(chuàng)建數(shù)據(jù)庫及底層模型
我這里簡單的以默認的sqlite3數(shù)據(jù)庫作為了我的博客系統(tǒng)的數(shù)據(jù)庫了,當然你也可以自己制定需要的數(shù)據(jù)庫,一般來說sqlite3都能滿足需求。在setting.py里面可以這樣進行設置。
# Database # https://docs.djangoproject.com/en/1.9/ref/settings/#databases DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': 'MyBlog.db', 'USER':'', 'PASSWORD':'', 'HOST':'', 'PORT':'', } }
建好了數(shù)據(jù)庫,接下來就是模型的創(chuàng)建了。因為我創(chuàng)建的是博客系統(tǒng),所以必不可少的要發(fā)布關(guān)于博客的內(nèi)容,于是需要有標題,內(nèi)容,發(fā)布時間這些屬性,詳情如models.py文件
from __future__ import unicode_literals from django.contrib import admin from django.db import models # create the blog model class BlogPost(models.Model): title = models.CharField(max_length=150) body = models.TextField() timestamp = models.DateTimeField() def __unicode__(self): return self.title
由于需要管理員對發(fā)布的博客進行管理,所以我們要對發(fā)布的博客設置一個管理模型
# set the admin page for BlogPost class BlogPostAdmin(admin.ModelAdmin): list_display = ('title','timestamp') # register the model (especially important admin.site.register(BlogPost)
所以整個models.py文件里面就應該是這樣的了。
from __future__ import unicode_literals from django.contrib import admin from django.db import models # create the blog model class BlogPost(models.Model): title = models.CharField(max_length=150) body = models.TextField() timestamp = models.DateTimeField() def __unicode__(self): return self.title # set the admin page for BlogPost class BlogPostAdmin(admin.ModelAdmin): list_display = ('title','timestamp') # register the model (especially important admin.site.register(BlogPost)
接下來,就是同步一下數(shù)據(jù)庫和模型之間的聯(lián)系了。如果不做同步操作的話,就很有可能報出
django.db.utils.OperationalError: unable to open database file
而且這里也是很重要的一個環(huán)節(jié)。那就是關(guān)于Django版本的問題,我之前就在這上面栽過一次。
django < 1.7 時:
python manage.py syncdb
django > 1.7 時:
python manage.py makemigrations
python manage.py migrate
完善MVC模式
其實前面的步驟而言,我們已經(jīng)是完成了model這個模塊的功能了,接下來就是做好視圖的映射就可以了。
•V(views.py)視圖層
我們需要在這個文件里面定義好底層的邏輯處理。這決定著要返回給用戶一個什么樣的response。至于采用哪種渲染方式,大家就不要在這上面浪費不必要的時間了。render_to_response就足夠了。
# create the view for blog show def myBlogs(request): blog_list = BlogPost.objects.all() return render_to_response('BlogTemplate.html',{'blog_list':blog_list})
這里面用到了模板文件,還傳給了模板一個列表類型的參數(shù),這些我們待會再敘。
•C(controller)urls.py
可以說這個文件將Django各部分松耦合的功能銜接到了一起,完成了整個項目的運轉(zhuǎn)的非核心的核心了,是關(guān)于如何映射的邏輯的處理。接下來我們就將我們的博客系統(tǒng)設置一下吧。
from django.conf.urls import url from django.contrib import admin from MyBlog.views import * urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^myBlogs/$',myBlogs), ]
關(guān)于如何映射,我的上一篇文章里面有詳細的介紹,PyCharm開發(fā)Django基礎配置。有興趣的可以參考一下。好了,這次我們在完成了admin管理員用戶的設置之后,就可以運行我們的程序了。
python manage.py runserver
出現(xiàn)了:
Performing system checks... System check identified no issues (0 silenced). June 05, 2016 - 11:39:27 Django version 1.9.6, using settings 'MyDjango.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CTRL-BREAK.
這時就可以在瀏覽器中輸入
http://127.0.0.1:8000/admin,登陸成功后可以點擊下面的Blog Posts編輯博文了。然后點擊SAVE 按鈕,就可以發(fā)布我們的博客。接下來在瀏覽器中輸入
http://127.0.0.1:8000/myBlogs/ 訪問我們的博客系統(tǒng)了。
這樣就實現(xiàn)了我們的博客系統(tǒng)的建立了。但是由于沒有添加樣式,所以看起來不是很好看,所以我們要添加以下模板的樣式。
模板配置
接著剛才的繼續(xù),關(guān)于模板,這里面可謂是有著很深的設計哲學。了解過的大家肯定都會有感觸,我就不多說了。
接下來就為我們的博客系統(tǒng)設置一下模板吧。
•父模板base.html
按照django對模板的繼承設置,我們可以制作一個父模板。如下:
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <title>標題</title> </head> <style type="text/css"> body{ color: #efd; background: #BBBBBB; padding: 12px 5em; margin:7px; } h1{ padding: 2em; background: #675; } h2{ color: #85F2F2; border-top: 1px dotted #fff; margin-top:2em; } p{ margin:1em 0; } </style> <body> <h1>XX博文</h1> <h3>小生不才,但求簡約!</h3> {% block content %} {% endblock %} </body> </html>
•然后就是子模板BlogTemplate.html
{% extends "base.html" %} {% block content %} {% for post in blog_list %} <h2>{{ post.title }}</h2> <p>{{ post.timestamp }}</p> <p>{{ post.body }}</p> {% endfor %} {% endblock %}
需要注意的就是模板中的模板標簽以及模板變量都應該與views.py文件對應的函數(shù)中的字典變量相一致,否則django雖然不會報錯,但也是不會顯示數(shù)據(jù)的。
接下來刷新一下,輸入http://127.0.0.1:8000/admin/
點擊add按鈕,開始添加你的博文吧。
然后在瀏覽器中輸入
http://127.0.0.1:8000/myBlogs/
.你就可以看到你的博客列表了,如圖
大家可能已經(jīng)看到了,問題就出在點擊標題沒有進入到相關(guān)的詳情頁面,那是因為還沒有添加這個功能呢。(^__^) 嘻嘻……
總結(jié)
今天一起做了一個簡單的博客系統(tǒng),雖然外觀看起來并不是很好看,但是內(nèi)容什么的差不多就是這樣了。還有很多的地方需要完善。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用pandas模塊實現(xiàn)表之間的關(guān)聯(lián)
在數(shù)據(jù)分析和處理中,表之間的關(guān)聯(lián)是非常常見的操作,本文為大家介紹了pandas中實現(xiàn)表之間的關(guān)聯(lián)有四種方式,感興趣的小伙伴可以了解一下2023-07-07解決win7操作系統(tǒng)Python3.7.1安裝后啟動提示缺少.dll文件問題
這篇文章主要介紹了解決win7操作系統(tǒng)Python3.7.1安裝后啟動提示缺少.dll文件問題,本文給大家提供兩種解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07pandas object格式轉(zhuǎn)float64格式的方法
下面小編就為大家分享一篇pandas object格式轉(zhuǎn)float64格式的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04