创建项目,在命令行中输入:django-admin startproject mysite

则会创建一个名为mysite的项目。项目结构如下:

+mysite

|--+ugo

|          |--+migrations

|          |--__init__.py

|          |--admin.py

|          |--apps.py

|          |--models.py

|          |--tests.py

|          |--views.py

|--+mysite

|               |--+__pycache__

|               |--__init__.py

|               |--settings.py

|               |--urls.py

|               |wsgi.py

|--manage.py

|--db.sqlite3

|--+templates

|--+static

manage.py是主要的管理程序。

db.sqlite3是在执行完python manage.py migrate之后产生的,用于对应数据库。

urls.py用于指明什么样的url对应哪一种方法的对应关系。

settings用于设置整个项目,例如加入什么功能。

wsgi.py部署到主机上才会用到。

在mysite目录下执行 python manage.py startapp ugo ,会在mysite下创建一个app。ugo文件夹中包含__init__.py文件,说明

它是作为一个可导入的包,所以需要导入ugo才能看到这个模块中的内容。需要在settings中的变量INSTALLED_APPS中加

入ugo。

views.py用于编写被调用函数的具体实现

如果有必要设置模板template文件,让正确的模板在views.py中可调用,用于把函数执行完的结果转移到对应的模板中。可自行在mysite下创建文件夹templates存放html文件。创建完后在settings.py中把TEMPLATES变量中的DIRS的设置为templates的具体位置,例'DIRS': [os.path.join(BASE_DIR,'templates').repalce('\\','/')],

如果有必要设置models.py,建立与数据库的对应关系。

模板的使用

1.在setting.py中设置templates模板的目录

2.在urls.py中设置网址与函数(index)的映射

3.创建在templates下创建编辑index.html文件

4.在views.py视图中编辑index函数,函数返回的经过加工和传参的Index.html文件以HttpResponse(html)的形式

5.在model.py中设置存储数据的模板,用于和数据库进行交互

设置urls.py的网址与函数的对应关系

ffrom django.conf.urls import url

from django.contrib import admin

from ugo.views import index

urlpatterns = [

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

url(r'^$',index)

]

url()的第一个参数是正则表达式。用于匹配网址域名后的内容,r'^$'表示域名后没有任何内容,即http://localho

st:8000/这个网址,则会调用函数index.正则表达式中使用小括号括起来的部分会被当作参数,传给后面的函数。

在templates目录下创建index.html文件(使用{{now}}把变量now传入)

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>

我的第一个Django网站

</title>

</head>

<body>

<h1>欢迎光临</h1>

<h2>现在时刻: {{now}}</h2>

</body>

</html>

如果传递的变量是列表形式,在模板中可用for循环:

<h3>User lists</h3>

<ul>

{% for user in userlist %}

<li>{{user.name}}</li>

{% empty %}

<p>There is no user in the list</p>

{% endfor %}

</ul

{% for user in userlists %}和{% endfor %} 是一对。如果userlists是空列表就会显示放在{% empty %}下的内容。

编辑views.py的index(request)函数

from django.http import HttpResponse

from django.template.loader import get_template

from datetime import datetime

def index(request):

template=get_template('index.html')

html=template.render({'now':datetime.now})

return HttpResponse(html)

导入HttpResponse把输出的内容转换成HTTP的格式。

使用get_template()加载index.html文件,然后使用方法render()以字典形式传入变量now.对与多个入参变量,可以

使用locals()方法,它的功能是以字典形式返回所有当前在内存中的局部变量。例

template=get_template('index.html')

now=datetime.now

userlists=list()

userlist.append({'nane':'Richard'})

userlist.append({'nane':'John'})

userlist.append({'nane':'Mary'})

html=template.render(locals())

就可以把now,userlists这两个变量一并传递到template.renders中

这时在mysite目录下运行python manage.py runserver ,然后在浏览器中输入http://localhost:8000就会看到

‘欢迎光临!’这几个字。

tempalte中的模板也可以设置一个基础模板,然后在个性化的模板中继承该模板

例,编写基础模板:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>{%block title %}{% endblock %}</title>

<body>

<header>...</header>

<nav>...</nav>

{% block main %} {% endblock %}

<footer>...</footer>

</body>

</head>

</html>

保存为base.html,然后在子模板中使用 extends这个文件,,然后设置title和content就可以了

{% extends 'base.html' %}

{% block title %} 欢迎光临 {% endblock %}

{% block main % }

...这里放所有想要呈现的index.html中的主要内容...

{% endblock  %}

详情可参考 https://docs.djangoproject.com/en/1.7/topics/templates/

关于静态文件,不需要设置url与函数对应(通过函数来加工),直接显示要获取的文件,就是静态文件。在settings.py中

设置静态文件的根网址 STATIC_URL='/static/',

也就是网址前部分为http://localhost:8000/static时就会直接到静态文件目录读取文件。

设置静态文件的本地路径 STATICFILES_DIRS=[os.path.join(BASE_DIR,'static'),],在项目路径下创建文件夹static,在static里可按文件类别分别创建文件夹js,css,images.

在templates模板文件中获取静态文件:

...省略...

{% load staticfiles %}

<img src="{% static 'images/logo.png' %}" width=150/>

...省略...

5.models.py的基本格式如下:

class urllist(models.Model):

src_url=models.URLField()

short_url=models.CharField(max_length=20)

count=models.PositiveIntegerField()

def __unicode__(self):

return self.short_url

models中的数据类型及特性,具体可查看 https://docs.djangoproject.com/en/1.9/ref/models/fields/

在models中创建class,存盘后,可使用命令 python manage.py check 以确认所有设置的正确性。

python manage.py makemigrations ugo,最后的ugo表示我们创建的app ugo。

c:\pythonScripts\mysite>python manage.py check

System check identified no issues (0 silenced).

c:\pythonScripts\mysite>python manage.py makemigrations ugo

Migrations for 'ugo':

ugo\migrations\0001_initial.py

- Create model urllist

c:\pythonScripts\mysite>python manage.py migrate

Operations to perform:

Apply all migrations: admin, auth, contenttypes, sessions, ugo

Running migrations:

Applying ugo.0001_initial... OK

以上三步都没报错,说明这个数据表已经被创建完成,可以拿来使用了。

可以启用django预装的admin功能操作DB.sqlite3数据库。

在APP目录(ugo)下找到admin.py,将我们的数据模型做好注册即可:

from django.contrib import admin

# Register your models here.

from ugo.models import urllist

admin.site.register(urllist)

然后创建数据库的管理员账号

python manage.py createsuperuser

Username: admin

Email address: skynet.tw@gmail.com

Password:

Password (again):

在启动web服务器(python manage.py runserver)后,在浏览器中输入:localhost:8000/admin就可看到数据库

登陆界面,登陆后可看到admi主界面。

Django小示例的更多相关文章

  1. ReactNative新手学习之路06滚动更新ListView数据的小示例

    本节带领大家学习使用ListView 做一个常用的滚动更新数据示例: 知识点: initialListSize={200} 第一次加载多少数据行 onEndReached={this.onEndRea ...

  2. MVC客户端验证的小示例

    MVC客户端验证的小示例 配置客户端验证的可用性: <configuration> <appSettings>  <add key="ClientValidat ...

  3. 【.Net】Socket小示例

    引言 项目中用到了Socket,这里做个控制台小示例记录一下. Client 客户端的Receive用了异步方法,保持长连接,可以随时发送消息和响应服务端的消息,如下 static string Cl ...

  4. Django+小程序技术打造微信小程序助手 ✌✌

    Django+小程序技术打造微信小程序助手 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 从零到一的完整项目开发实战过程,项目开发聚焦重要知识点,先原理后实战 ...

  5. CentOS7 安装 RocketMQ 实践和小示例

    CentOS7 安装 RocketMQ 实践和小示例 1.通过 SSH 工具(比如 XShell)连接到 CentOS7 服务器上: 2.进入到 /usr/local 目录中: cd /usr/loc ...

  6. Django+小程序技术打造微信小程序助手

    Django+小程序技术打造微信小程序助手   整个课程都看完了,当前这个课程的分享可以往下看,下面有某盘的链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,同时也分享下自己的总结 ...

  7. Django 小实例S1 简易学生选课管理系统 12 CSS样式完善

    Django 小实例S1 简易学生选课管理系统 第12节--CSS样式完善 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块的逻辑代码到这里 ...

  8. Django 小实例S1 简易学生选课管理系统 11 学生课程业务实现

    Django 小实例S1 简易学生选课管理系统 第11节--学生课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,学生需要拥 ...

  9. Django 小实例S1 简易学生选课管理系统 10 老师课程业务实现

    Django 小实例S1 简易学生选课管理系统 第10节--老师课程业务实现 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 课程模块中,老师将要使 ...

随机推荐

  1. gvim写html代码时如何快速地跳转到一个标签的结束位置: 终极插件: matchit.vim

    gvim写html代码时如何快速地跳转到一个标签的结束位置 参考这个vimrc的配置, 里面有一些 很好的东西, 配置很有用, 以前没有用到: http://www.cnblogs.com/wangj ...

  2. spring boot 启动后执行初始化方法

    http://blog.csdn.net/catoop/article/details/50501710 1.创建实现接口 CommandLineRunner 的类 package org.sprin ...

  3. 【TCP/IP详解 卷一:协议】第9章 IP选路

    推荐链接:网络地址与主机地址 9.1 引言 路由选择程序(daemon),通常这是一个用户进程.在大多数的Unix系统中,大多数的路由选择程序都是路由程序和网关程序. 路由表经常被IP访问,但是它被路 ...

  4. mui --- 怎么获取百度地图定位功能

    <!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. MongoDB(课时17 更新函数)

    3.4.3 数据更新操作 MongoDB数据存的是副本数据, 最终的数据还要保存在传统的数据库里,所以如果关系型数据库里数据变了,最好的方法是删除里面的MongoDB数据重新插入. 在MongoDB里 ...

  6. springboot全局配置文件可设置的属性

    # =================================================================== # COMMON SPRING BOOT PROPERTIE ...

  7. Codeforces 834D - The Bakery(dp+线段树)

    834D - The Bakery 思路:dp[i][j]表示到第j个数为止分成i段的最大总和值. dp[i][j]=max{dp[i-1][x]+c(x+1,j)(i-1≤x≤j-1)},c(x+1 ...

  8. 一个纯净的webpack4+angular5脚手架

    该篇主要是结合刚发布不久的webpack4,搭建一个非cli的angular5的脚手架demo,主要分为以下几个方面阐述下脚手架结构: # 脚手架基础架构(根据angular5的新规范) /** * ...

  9. C# DataTable按指定列排序

    C#提供的内置对象DataTable功能特别的强大,如果我们需要对DataTable中的某一列进行排序怎么处理呢,具体代码如下: DataTable dt = new DataTable(); dt. ...

  10. LeetCode--175--组合两个表

    问题描述: 表1: Person +-------------+---------+ | 列名 | 类型 | +-------------+---------+ | PersonId | int | ...