Django初探一

小白的Django学习笔记。本人随便写写,本人用的mac+Python3.6。

一、环境搭建

1. 安装Django

由于我的运行环境是mac+python3.6,所以我用的是Django1.11版本:

pip install Django==1.11
复制代码

其他版本如下:

2. 创建项目

本人创建的项目名称叫:blogDemo,所以代码如下:

django-admin startproject blogDemo
复制代码
3. 创建应用

然后进入和manage.py同级的项目文件夹,用命令创建应用myblog:

python manage.py startapp myblog
复制代码

启动服务器:

python manage.py runserver
复制代码

启动服务器后,获取到的地址,就是本项目根地址: Django version 1.11, using settings 'blogDemo.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CONTROL-C. 改变端口:

python manage.py runserver 9999(端口号)
复制代码

二、hello world

1. 项目结构介绍

项目文件下的settings.py是项目的配置文件,包括是否debug模式,APP注册,语言设置等等。我把项目的根地址改成localhost,便于访问。在setting.py中ALLOWED_HOSTS = ['localhost']。urls.py是项目的url文件,所有的url都要在urlpatterns注册。其他的文件暂时不管。 应用文件下的的admin.py是后台管理系统的管理文件。models.py相当于MVC中的M文件,一个类对应一张表,Django直接用类来操作数据库。views.py是主要响应文件,每个响应对应一个函数,函数必须返回一个响应,每个响应函数对应一个url。其他的文件暂时不管,一时记不住不管,往下写代码就行。

2. 开始写代码

所以的应用必须在settings.py中注册:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'myblog'
]
复制代码

然后在views.py中写页面数据代码:

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
	return HttpResponse('hello world')
复制代码

所有的页面都要在urls.py中注册:

from django.conf.urls import url
from django.contrib import admin
from myblog import views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^index/', views.index),
]
复制代码

然后打开网址localhost:8000/index效果就出来啦,当然前提得是你启动了服务器python manage.py runserver。

3. url注册

由于项目的复杂性,所有应用的url都在urls.py中注册,容易重名,不易读,也不便管理,所以在应用myblog文件夹下新建一个urls.py用于管理本应用的url。项目的urls.py文件代码如下:

from django.conf.urls import url,include
from django.contrib import admin


urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^myblog/', include('myblog.urls')),
]
复制代码

然后在应用文件夹下的urls.py中代码如下:

from django.conf.urls import url
from . import views

urlpatterns = [

    url(r'^index/$', views.index),
]
复制代码

然后打开网址**localhost:8000/myblog/index/**测试。

三、templates

1. 创建template文件:index.html

由于Django是由settings.py中的INSTALLED_APPS应用添加顺序来查找templates,所以不同应用下的html文件重名后会发生冲突。解决方案是,在应用目录的templates下,创建与应用同名的文件夹,把html文件放在此文件夹里。

2.显示index.html

在views.py中返回此界面:

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
	return render(request,'myblog/index.html',{'param1':'hello 你好'})
复制代码

在index.html中显示参数param1的数据:<h1>{{param1}}}</h1>,参数的数据显示用{{}}括起来。更多资料点这里

四、models

1. 在APP目录中的models.py中创建类,继承models.Model。
from django.db import models

class Artical(models.Model):
	title = models.CharField(max_length=32)
	content = models.TextField(max_length=100)
复制代码

更多变量的属性在这里

2. 生成数据表

先输入命令:python manage.py makemigrations然后再输入命令python manage.py migrate。 完成数据迁移后应用目录中会出现migrations的文件夹,里面有0001_initial.py文件,这个文件就是Artical模型的初始化文件,你可以在终端用命令python manage.py sqlmigrate myblog 0001查看sql语句。

3 . 插入并显示数据

python manage.py migrate 过后,文件中多了一个db.sqlite3的数据库。除了用打开数据库认为添加数据,还可以代码添加,详细资料点这里。在models.py中代码如下:


class ArticalManager(models.Manager):
    def create_artical(self,title,content):
        artical =self.create(title = title,content = content)
        return artical	
class Artical(models.Model):
	title = models.CharField(max_length=32)
	content = models.TextField(max_length=100)
	objects = ArticalManager()
复制代码

然后views.py中实现数据响应:

from django.shortcuts import render
from django.http import HttpResponse
from . import models

def index(request):
	articals = models.Artical.objects.all()  #获取全部数据
    #artical = models.Artical.objects.get(pk=1)  获取第一行数据
	if len(articals) == 0:
		artical = models.Artical.objects.create_artical("这是标题","这是内容")
		artical.save()
		articals = models.Artical.objects.all()
	return render(request,'myblog/index.html',{'param1':'我的首页','articals':articals})
复制代码

在index.html中显示数据:

<body>
	<h1>{{param1}}</h1>
	{% for artical in articals %}
		<a href="">{{artical.title}}</a>
	{% endfor %}
</body>
复制代码

五、admin操作

1. 创建用户

输入命令python manage.py createsuperuser创建超级用户,然后登陆后台管理系统localhost:8000/admin/。就看到以下界面:

为什么没有我的Artical表呢,因为Artical没有在admin注册,所以admin并不知道它。在admin.py中写下代码: admin.site.register(models.Artical)然后首页就有了Artical表,点进Artical详情后显示的是Artical object。如果想要显示标题和其他字段,代码如下:

from django.contrib import admin
from . import models

class ArticalAdmin(admin.ModelAdmin):
	list_display = ('title','content')
admin.site.register(models.Artical,ArticalAdmin)
复制代码

然后效果如下:

2. 改变语言

后台管理系统一般默认为英语,想中文显示,在settings.py中把LANGUAGE_CODE 改成 'zh_Hans' 就好啦。

3. 过滤器

比如你在Artical的后台管理界面,只想看某一天的记录,那么我们在models.py中添加一个字段pub_time = models.DateField(null=True),然后在admin.py中的ArticalAdmin类中添加list_filter = ('pub_time',),最后要进行数据迁移python manage.py makemigrationspython manage.py migrate。效果如下:

最后,还有好多,懒得写了。

转载于:https://juejin.im/post/5a31d71251882531d8286c34

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值