用Python+Django在Eclipse環境下開發web網站

weixin_34007906發表於2014-03-12

一、建立一個專案
如果這是你第一次使用Django,那麼你必須進行一些初始設定。也就是通過自動生成程式碼來建立一個Django專案--一個Django專案的設定集,包含了資料庫配置、Django詳細選項設定和應用 特性配置,具體操作步驟如下所示。

1.新建Django專案


選擇sqlite資料庫

2.建立網站模組app

3.測試新建的模組是否正常

Validating models...

0 errors found
March 12, 2014 - 10:26:53
Django version 1.6.2, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

伺服器啟動起來後,去瀏覽器輸入網址:http://127.0.0.1:8000,你會看到一個令人愉悅的,柔和的淡藍色 “Welcome to Django” 頁面。表示它已正常工作!

讓我們來看看mysite都建立了些什麼:

這些檔案分別是:
a、外層mysite目錄只是你專案的一個容器。對於Django來說該目錄名並不重要;你可以重新命名為你喜歡的。
b、manage.py: 一個實用的命令列工具,可讓你以各種方式與該Django專案進行互動。
c、內層mysite目錄是你專案中的實際Python包。該目錄名就是Python包名,通過它你可以匯入它裡面的任何東西。(e.g.import mysite.settings).
d、mysite/__init__.py:一個空檔案,告訴Python該目錄是一個Python包。
e、mysite/settings.py:該Django專案的設定/配置。
f、mysite/urls.py:該Django專案的URL宣告;一份由Django驅動的網站“目錄”。
g、mysite/wsgi.py:一個WSGI相容的Web伺服器的入口,以便執行你的專案。

更改埠號
預設情況下,:djadmin:runserver 命令啟動的開發伺服器只監聽本地IP的8000埠。

如果你想改變伺服器的埠,把它作為一個命令列引數傳遞即可。例如以下命令啟動的伺服器將監聽8080埠:

C:\Users\D-117>cd F:\workspace\mysite\src\mysite\ #manage.py檔案所在目錄,即mysite專案下
C:\Users\D-117>f:
F:\workspace\mysite\src\mysite>python manage.py runserver 8080
Validating models...

0 errors found
March 12, 2014 - 10:31:27
Django version 1.6.2, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8080/
Quit the server with CTRL-BREAK.

如果你想改變伺服器IP,把它和埠號一起傳遞即可。因此,要監聽所有公共IP地址(如果你想在其他電腦上炫耀你的工作),請使用:
python manage.py runserver 0.0.0.0:8000

資料庫設定
現在,編輯 mysite/settings.py 。 這是一個普通的Python模組,包含了代表Django設定的模組級變數。 更改DATABASES中'default'下的以下鍵的值,以匹配您的資料庫連線設定。
a、ENGINE – 從 'django.db.backends.postgresql_psycopg2', 'django.db.backends.mysql', 'django.db.backends.sqlite3', 'django.db.backends.oracle' 中選一個
b、NAME – 你的資料庫名。如果你使用 SQLite,該資料庫將是你計算機上的一個檔案;在這種情況下,:setting:NAME 將是一個完整的絕對路徑,而且還包含該檔案的名稱。如果該檔案不
存在,它會在第一次同步資料庫時自動建立(見下文)。當指定路徑時,總是使用正斜槓,即使是在Windows下(例如:`C:/homes/user/mysite/sqlite3.db`) 。
c、USER – 你的資料庫使用者名稱 ( SQLite 下不需要) 。
d、PASSWORD – 你的資料庫密碼 ( SQLite 下不需要) 。
e、HOST – 你的資料庫主機地址。如果和你的資料庫伺服器是同一臺物理機器,請將此處保留為空 (或者設定為 127.0.0.1) ( SQLite 下不需要) 。
如果你是新建資料庫,我們建議只使用 SQLite ,將 ENGINE 改為 'django.db.backends.sqlite3' 並且將 NAME 設定為你想存放資料庫的地方。 SQLite 是內建在 Python 中的,因此你不需要安裝任何東西來支援你的資料庫。

注意:
如果你使用PostgreSQL或者MySQL,確保你已經建立了一個資料庫。還是通過你的資料庫互動介面中的“CREATE DATABASE database_name;”命令做到這一點的。
如果你使用SQLite,你不需要事先建立任何東西 - 在需要的時候,將會自動建立資料庫檔案。

當你編輯 settings.py 時,將 TIME_ZONE 修改為你所在的時區。預設值是美國中央時區(芝加哥)。同時,注意檔案底部的 INSTALLED_APPS 設定。它儲存了當前 Django 例項已啟用的所
有 Django 應用。每個應用可以被多個專案使用,而且你可以打包和分發給其他人在他們的專案中使用。

預設情況下,:setting:INSTALLED_APPS 包含以下應用,這些都是由 Django 提供的:

django.contrib.auth – 身份驗證系統。
django.contrib.contenttypes – 內容型別框架。
django.contrib.sessions – session 框架。
django.contrib.sites – 網站管理框架。
django.contrib.messages – 訊息框架。
django.contrib.staticfiles – 靜態檔案管理框架。

這些應用在一般情況下是預設包含的。

所有這些應用中每個應用至少使用一個資料庫表,所以在使用它們之前我們需要建立資料庫中的表。要做到這一點,請執行以下命令:python manage.py syncdb,具體操作下面會闡述。

至此,專案開發環境建立好了,我們可以開工了。

二、建立模型

4.編輯程式碼
4.1修改blog.models.py

from django.db import models
from django.contrib import admin

# Create your models here.
class BlogPost(models.Model):
    title = models.CharField(max_length = 150)
    content = models.TextField()
    timestamp = models.DateTimeField()
    
class BlogPostAdmin(admin.ModelAdmin):
    list_display = ('title', 'content', 'timestamp')

admin.site.register(BlogPost, BlogPostAdmin)

我們將建立一個BlogPost模型,包含title、content、timestamp三個欄位。每個模型都繼承自django.db.models.Model子類的類來描述。 每個模型
都有一些類變數,每一個類變數都代表了一個資料庫欄位。

每個欄位由一個 Field 的例項來表現 – 比如 CharField 表示字元型別的欄位和 DateTimeField 表示日期時間型的欄位。這會告訴 Django 每個
欄位都儲存了什麼型別的資料。

每一個 Field 例項的名字就是欄位的名字(如: title、content、timestamp),其格式屬於親和機器式的。在你的 Python 的程式碼中會使用這個
值,而你的資料庫會將這個值作為表的列名。

4.2修改blog.views.py

# Create your views here.
from django.template import loader,Context
from django.http import HttpResponse
from blog.models import BlogPost

def archive(request):
    posts = BlogPost.objects.all()
    t = loader.get_template('archive.html')
    c = Context({'posts': posts})
    return HttpResponse(t.render(c))

4.3修改mysite.setting.py,找到下面部分進行修改

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'blog',
)

4.4修改mysite.urls.py

from django.conf.urls import patterns, include, url

from django.contrib import admin
admin.autodiscover()

from blog.views import archive

urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'mysite.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),

    url(r'^admin/', include(admin.site.urls)),
    url(r'^blog/', archive),
)

5.建立樣式網頁模板
請在包blog下新增templates資料夾,並在templates下建立兩個網頁檔案:archive.html和base.html

5.1編輯archive.html

{% extends "base.html" %}  
{% block content %}  
{% for post in posts %}  
<h1>{{ post.title}}</h1>  
<p>{{ post.content }}</p>
<p>{{ post.timestamp|date:"1, F jS"}}</p>
{% endfor %}  
{% endblock %}

5.2編輯base.html

<html>  
  <style type="text/css">  
    body { color: #edf; background: #453; padding: 0 5em; margin:0 }  
    h1 { padding: 2em lem; background:#675 }  
    h2 { color: #bf8; border-top: 1px dotted #fff; margin-top: 2em }  
    p { margin: lem 0 }  
  </style>  
  <body>  
    <h1><center>Alexia's Blog</center></h1>  
    {% block content %}  
    {% endblock %}  
  </body>  
</html>

三、同步資料庫

設定你的賬號和密碼,為登陸blog的管理後臺作準備。

Creating tables ...
Creating table django_admin_log
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table auth_user_groups
Creating table auth_user_user_permissions
Creating table auth_user
Creating table django_content_type
Creating table django_session

You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): yes
Username (leave blank to use 'd-117'): root
Email address: root@qq.com
Password: root
Password (again): root
Superuser created successfully.
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)
Finished "F:\workspace\mysite\src\mysite\manage.py syncdb" execution.

四.執行測試
登陸介面,登陸賬號和密碼是初始化資料庫的時候設定的。

登入成功後跳轉到下面頁面:

在該頁面可以新增blog文章:

釋出成功後,輸入網址:http://127.0.0.1:8000/blog/進行檢視,測試成功!

如果,您認為閱讀這篇部落格讓您有些收穫,不妨點選一下右下角的【推薦】。
如果,您希望更容易地發現我的新部落格,不妨點選一下左下角的【關注我】。
如果,您對我的部落格所講述的內容有興趣,請繼續關注我的後續部落格,我是【Ruthless】。

本文版權歸作者和部落格園共有,歡迎轉載,但未經作者同意必須保留此段宣告,且在文章頁面明顯位置給出原文連線,否則保留追究法律責任的權利。

相關文章