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脚本实现虾米网签到功能
Apr 12 Python
python+matplotlib实现动态绘制图片实例代码(交互式绘图)
Jan 20 Python
python读取和保存视频文件
Apr 16 Python
Python3使用turtle绘制超立方体图形示例
Jun 19 Python
python多进程控制学习小结
Oct 31 Python
Python3爬虫爬取英雄联盟高清桌面壁纸功能示例【基于Scrapy框架】
Dec 05 Python
python实现AES和RSA加解密的方法
Mar 28 Python
Python中正反斜杠(‘/’和‘\’)的意义与用法
Aug 12 Python
浅谈Python3 numpy.ptp()最大值与最小值的差
Aug 24 Python
解决Pytorch 加载训练好的模型 遇到的error问题
Jan 10 Python
Python之字典对象的几种创建方法
Sep 30 Python
python OpenCV学习笔记
Mar 31 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提取中文首字母
2008/04/09 PHP
php获取域名的google收录示例
2014/03/24 PHP
PHP文件管理之实现网盘及压缩包的功能操作
2017/09/20 PHP
最近项目写了一些js,水平有待提高
2009/01/31 Javascript
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
2010/08/03 Javascript
JS重要知识点小结
2011/11/06 Javascript
js设置function参数默认值(适合没有传参情况)
2014/02/24 Javascript
轻松创建nodejs服务器(5):事件处理程序
2014/12/18 NodeJs
jquery删除指定子元素代码实例
2015/01/13 Javascript
JS实现带鼠标效果的头像及文章列表代码
2015/09/27 Javascript
JavaScript实现带播放列表的音乐播放器实例分享
2016/03/07 Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
2016/06/14 Javascript
基于Angularjs+mybatis实现二级评论系统(仿简书)
2017/02/13 Javascript
微信小程序本作用域下调用全局JS详解及实例
2017/02/22 Javascript
zTree实现节点修改的实时刷新功能
2017/03/20 Javascript
详谈Node.js之操作文件系统
2017/08/29 Javascript
除Console.log()外更多的Javascript调试命令
2018/01/24 Javascript
详解处理Vue单页面应用SEO的另一种思路
2018/11/09 Javascript
详解Vue中watch的详细用法
2018/11/28 Javascript
微信小程序开发常见问题及解决方案
2019/07/11 Javascript
python中的字典详细介绍
2014/09/18 Python
python通过pil将图片转换成黑白效果的方法
2015/03/16 Python
详解python string类型 bytes类型 bytearray类型
2017/12/16 Python
Python基于OpenCV实现视频的人脸检测
2018/01/23 Python
对Python中Iterator和Iterable的区别详解
2018/10/18 Python
Python 新建文件夹与复制文件夹内所有内容的方法
2018/10/27 Python
对python当中不在本路径的py文件的引用详解
2018/12/15 Python
11个Python Pandas小技巧让你的工作更高效(附代码实例)
2019/04/30 Python
Python实现滑动平均(Moving Average)的例子
2019/08/24 Python
美国本地交易和折扣网站:LocalFlavor.com
2017/10/26 全球购物
印尼旅游网站:via
2017/11/12 全球购物
美德少年事迹材料1000字
2014/08/21 职场文书
幼儿园六一活动总结
2014/08/27 职场文书
道歉的话怎么说
2015/05/12 职场文书
mysql 带多个条件的查询方式
2021/06/05 MySQL
python中pd.cut()与pd.qcut()的对比及示例
2022/06/16 Python