python框架django基础指南


Posted in Python onSeptember 08, 2016

Django简介:

Django是一个开放源代码的Web应用框架,由Python写成。采用了MVC的框架模式,即模型M,视图V和控制器C。不过在Django实际使用中,Django更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式。Django的主要目的是简便、快速的开发数据库驱动的网站,它强调代码复用,多个组件可以很方便的以“插件”形式服务于整个框架,Django有许多功能强大的第三方插件。

django是对象关系映射的 (ORM,object-relational mapping):以Python类形式定义你的数据模型,ORM将模型与关系数据库连接起来,你可以通过简单的API操作数据库,同时你也可以在Django中使用原始的SQL语句。Django可以运行在Apache上,也可以运行在支持WSGI,FastCGI的服务器上。支持多种数据库,已经支持Postgresql,MySql, Sqlite3,Oracle。

django安装

pip install Django

验证django的安装

import django
django.get_version()

创建一个django工程

django-admin.py startproject mysite

此时会自动生成一些目录和文件,最外层的manage.py,像是一个运行的入口,通过命令行的调用可以完成一些常用的功能,比如:

运行django的自带的web服务器:

python manage.py runserver http://127.0.0.1:8080

常用的同步或创建数据库表:

python manage.py syncdb

创建django project里面的子项目

python manage.py startapp polls

创建超级管理员:

python manage.py createsuperuser

还有setttings.py文件,是django的配置文件。

urls.py文件,是django用于匹配url的文件,哪个网址执行哪些后台代码(view)是在这里定义的。

Django MTV模式之----modle模型

Django采用了orm模式(对象关系映射),django的模型根据数据库表的内容定义了一个python类,这个类里面的成员和每一个数据库表里的字段一一对应;

类里面的成员类型也和数据库表里的字段类型也是对应的,名字其实也可以起的一样,看起来比较直观。这样每个类实例就代表了数据库里面的一条数据。

模型例子(在models.py里定义):

from django.db import models

class Poll(models.Model):
  question = models.CharField(max_length=200)
  pub_date = models.DateTimeField('date published')

class Choice(models.Model):
  poll = models.ForeignKey(Poll)d
  choice_text = models.CharField(max_length=200)
  votes = models.IntegerField(default=0)

django设置数据库:

settings.py文件里面的database可以定义你要使用的数据库类型,比如:

定义数据库为sqlite

'ENGINE': 'django.db.backends.sqlite3'

定义数据库为mysql

'ENGINE': 'django.db.backends.mysql'

执行django-admin.py startproject mysite, 然后再python manage.py runserver http://127.0.0.1:8080就算搭建了最简单的一个django web服务器,可通过 http://127.0.0.1:8080访问测试。另外在install_apps里面激活应用,执行pyhton manage.py syncdb,此时会根据定义的模型创建相应的数据库。

数据库操作例子:(假设File为定义的模型类)

获取所有数据:

all_filelist = File.objects.all()

获取所有数据并按某个字段排序:

all_filelist = File.objects.all().order_by('-id')

执行sql语句:

cursor = connection。cursor()
cursor.extcute("select * from info_path")
chaannels = cursor.fetchall()

过滤数据:

list=File.objects.all().filter(xxx=xxx)

根据主键查询

list=File.objects.all().get(id=1)

时间过滤:

results = File.objects.all().filter(time__range=(dayfrom, dayto))

创建新数据:

file = File(time=time,path=path,result=result)
file.save()

获取数据:

file.time
file.path
Python 相关文章推荐
python中django框架通过正则搜索页面上email地址的方法
Mar 21 Python
自己使用总结Python程序代码片段
Jun 02 Python
用pickle存储Python的原生对象方法
Apr 28 Python
Flask 让jsonify返回的json串支持中文显示的方法
Mar 26 Python
python画柱状图--不同颜色并显示数值的方法
Dec 13 Python
Python3.6+selenium2.53.6自动化测试_读取excel文件的方法
Sep 06 Python
Python实现word2Vec model过程解析
Dec 16 Python
Python-openCV读RGB通道图实例
Jan 17 Python
python中的selenium安装的步骤(浏览器自动化测试框架)
Mar 17 Python
浅谈Django中的QueryDict元素为数组的坑
Mar 31 Python
python json.dumps中文乱码问题解决
Apr 01 Python
python 如何区分return和yield
Sep 22 Python
python中星号变量的几种特殊用法
Sep 07 #Python
Python 实现 贪吃蛇大作战 代码分享
Sep 07 #Python
python 转换 Javascript %u 字符串为python unicode的代码
Sep 06 #Python
Python 编码处理-str与Unicode的区别
Sep 06 #Python
Python如何获取系统iops示例代码
Sep 06 #Python
python3编码问题汇总
Sep 06 #Python
用Python实现命令行闹钟脚本实例
Sep 05 #Python
You might like
注释PHP和html混合代码的小技巧(分享)
2016/11/03 PHP
PHP基于Closure类创建匿名函数的方法详解
2017/08/17 PHP
Yii框架getter与setter方法功能与用法分析
2019/10/22 PHP
JavaScript 对象模型 执行模型
2009/12/06 Javascript
jQuery 打造动态渐变按钮 详细图文教程
2010/04/25 Javascript
js substr、substring和slice使用说明小记
2011/09/15 Javascript
js对象关系图 方便dom操作
2012/03/18 Javascript
使用js修改客户端注册表的方法
2013/08/09 Javascript
jQuery实现密保互斥问题解决方案
2013/08/16 Javascript
jquery控制select的text/value值为选中状态
2014/06/03 Javascript
Javascript常用字符串判断函数代码分享
2014/12/08 Javascript
javascript中Date format(js日期格式化)方法小结
2015/12/17 Javascript
JavaScript编写带旋转+线条干扰的验证码脚本实例
2016/05/30 Javascript
BootStrap中
2016/12/10 Javascript
基于bootstrap的文件上传控件bootstrap fileinput
2016/12/23 Javascript
javascript常用经典算法详解
2017/01/11 Javascript
详解Nodejs之npm&package.json
2017/06/15 NodeJs
[10:49]2014国际邀请赛 叨叨刀塔第二期为真正的电竞喝彩
2014/07/21 DOTA
python正则表达式中的括号匹配问题
2014/12/14 Python
用Python的pandas框架操作Excel文件中的数据教程
2015/03/31 Python
Python打印scrapy蜘蛛抓取树结构的方法
2015/04/08 Python
基于wxpython实现的windows GUI程序实例
2015/05/30 Python
在windows系统中实现python3安装lxml
2016/03/23 Python
python3+PyQt5实现自定义分数滑块部件
2018/04/24 Python
利用python将图片版PDF转文字版PDF
2019/05/03 Python
python面向对象 反射原理解析
2019/08/12 Python
Pytorch十九种损失函数的使用详解
2020/04/29 Python
Python下载网易云歌单歌曲的示例代码
2020/08/12 Python
HTML5教程之html 5 本地数据库(Web Sql Database)
2014/04/03 HTML / CSS
函数指针的定义是什么
2016/08/14 面试题
置业顾问岗位职责
2014/03/02 职场文书
转让协议书范本
2014/04/15 职场文书
广告艺术设计专业自荐书
2014/07/08 职场文书
邹越感恩父母演讲稿
2014/08/28 职场文书
寻找成龙观后感
2015/06/12 职场文书
如何开发一个渐进式Web应用程序PWA
2021/05/10 Javascript