====启动django====

python manager.py runserver --host 0.0.0.0 --port 9008

python manager.py runserver --help可以查看所有的选项

python manager.py runserver --host 0.0.0.0 --port 9008 --setting=fms/settings_dev

这里可以用setting变量,设置环境信息,比如dev,test,production等

====1【request】http输入层====

【request获取GET参数】
id = request.GET.get('id')
print(id)

【request获取POST参数】

name = request.GET.get('name')
print(name) #获取复选框的多个值
ids = request.POST.getList('ids[]')
print ids #打印到文件
fp = open(file, 'a+')
for id in ids:
fp.write(str(id) + "\n")
fp.close()

====2【模板】django模板====

(16)spaceless 使用形式:{% spaceless %} (内容) {% endspaceless %} 意义:删除包围内容中的所有tab或者回车字符。

(22)linebreaks 使用形式:{{value|linebreaks}} 意义:value中的"\n"将被<br/>替代,并且整个value使用</p>包围起来,从而适和HTML的格式
(23)linebreaksbr 使用形式:{{value |linebreaksbr}} 意义:value中的"\n"将被<br/>替代

===关闭了Django的自动转义===
我们还可以通过{%autoescape off%}的方式关闭整段代码的自动转义,比如下面这样:

{% autoescape off %}
Hello {{ name }}
{% endautoescape %}

如果choices是数组,[,,,]
{% for choice in choices %}
{{choice.choice}} - {{choice.votes}} <br />
{% endfor %} 如果choices是dict,{a:, b:, c:}
{% for k,v in choices.items %}
<option value="{{k}}">{{v}}</option>
{% endfor %}
循环遍历参考文章:https://docs.djangoproject.com/en/2.1/ref/templates/builtins/

====3【response响应】====

【response】render和render_to_reponse区别

https://www.cnblogs.com/leonwen/p/5368239.html

如何将数据化后的模板返回到string中在程序中使用

from django.template.loader import render_to_string
str = render_to_string('f/project_search_list.html', data)

====4【DB】django db操作====

db = Project(project_id=1, content_id=1)
db.save()
#return

db = Project.objects.filter(project_id=1)
db.delete()
return

[DB细节]获取insert后的id

>>> b2 = Blog(name='Cheddar Talk', tagline='Thoughts on cheese.')
>>> b2.id # Returns None, because b doesn't have an ID yet.
>>> b2.save()
>>> b2.id # Returns the ID of your new object. #有判断插入是否成功
#假设b2.id是UUID类型,则使用如下判断
if str(b2.id) == '':
  insert_id = b2.id
#假设b2.id是int类型,且设置了默认值是0,则使用如下判断
if int(b2.id) == 0:
  insert_id = b2.id

参考链接:https://docs.djangoproject.com/en/dev/ref/models/instances/?from=olddocs#auto-incrementing-primary-keys

【DB】多个搜索条件(包含like)

object = Project.objects
if request.GET.get('name'):
object = object.filter(name__contains=request.GET.get('name'))
if request.GET.get('domain'):
object = object.filter(domain__contains=request.GET.get('domain'))
if request.GET.get('system_type') and request.GET.get('system_type') != '':
object = object.filter(system_type=int(request.GET.get('system_type')))
if request.GET.get('project_depart') and request.GET.get('project_depart') != '':
object = object.filter(project_depart=int(request.GET.get('project_depart')))
if request.GET.get('level') and request.GET.get('system_type') != '':
object = object.filter(level=int(request.GET.get('level')))
if request.GET.get('project_leader'):
object = object.filter(project_leader__contains=request.GET.get('project_leader')) Projects = object.all() #这里需要注意两点:,每次filter之后,都需要重新赋值到object;,如果有like操作,则要使用field_name__contains这个约定写法来完成like(这里包含两个下划线,不是一个);

[DB细节]更新逻辑

【model层写逻辑】
----mysql update---
patient_edit = PatientInfo.objects.get(id=patient_id) # object to update
patient_edit.name = 'New name' # update name
patient_edit.save() # save object

https://my.oschina.net/esdn/blog/803135

====5【service】业务逻辑层====

【service】其它

@login_required
@permission_required('accounts.add_project',raise_exception=True)
def project_add(request): if request.method == "POST":
form = ProjectForm(request.POST)
print(form)
if form.is_valid():
form.save()
else:
form = ProjectForm()
return HttpResponseRedirect(reverse('project_list')) 以上代码段中有几个关键函数,post传递参数,然后保存到数据库中
ProjectForm来组form数据,form.save()保存在数据库中 我们不需要组数据,我们需要的提取数据的信息 charField
Z:\dev\project\git\fms.xin.com\fms.xin.com\venv\lib\python3.\site-packages\django\db\models\fields\__init__.py django中对字段的设定,哪些是必填的,哪些是可以为空的
https://www.cnblogs.com/linxiyue/p/3662535.html
https://django-chinese-doc.readthedocs.io/zh_CN/latest/ref/models/fields.html

====附录,python文件操作====

http://www.runoob.com/python/python-files-io.html

python:django的更多相关文章

  1. Python:Django【基础篇】

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  2. python:Django 简介。

    Django是基Python的重要WEB框架. 1.安装Django Web框架 安装  pip 安装 在命令行模式 执行  [pip install django == 2.0]或者 [pip in ...

  3. Python:Django 项目中可用的各种装备和辅助

    1 Redis 数据库 2 MySQL 数据库 3 前端服务器 live-server 4 定时任务 django-crontab扩展 5 Docker 容器 --用来运行 FastDFS 分布式文件 ...

  4. Python之路【第十九章】:Django 数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  5. Python之路【第十八章】:Django基础

    Django基本配置 Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Se ...

  6. Python之路【第十七篇】:Django【进阶篇 】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

  7. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  8. Python之路【第十七篇】:Django之【进阶篇】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

  9. Python之路【第十七篇】:Django【进阶篇】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

随机推荐

  1. TFrame bug

    delphi 10.1.2 工程里有很多fram 正确的工程文件dproj中fram的定义是 <DCCReference Include="Unit15frame.pas"& ...

  2. OneinStack PHP多版本共存教程

    1. 安装OneinStack 选择lnmp模式,默认安装php5.4,安装步骤参考:http://oneinstack.com/install/ 选项如下: Install Nginx Do not ...

  3. ncnn 源码学习-Mat.h Mat.c

    纯小白记录下腾讯的ncnn框架源码的学习.纯粹写给自己看的,不保证正确性. Mat 类似于 caffe中的blob,是一个张量的存储结构体. 一.数据成员: 1.void * data 多维数据按一位 ...

  4. 6.5 Shell 算术计算

    6.5 Shell Arithmetic shell允许在其内计算表达式,可以通过以下方式使用:((中,let和带-i选项的declare命令中. 只能计算固定长度的整数,而且不会检查溢出,除0可以捕 ...

  5. debian下redis2.8.17安装过程

    下载redis源码包,我下载的是redis2.8.17 解压缩该源码包 tar zxf redis-2.8.17.tar.gz 进入解压缩后的目录 cd redis-2.8.17/ 添加redis用户 ...

  6. app与jvm 反向代理时config的设置(用于在web页面显示npm(就如tomcat)产生的页面)

    dev: { // Various Dev Server settings contentBase: ROOT, host: ip, port: 8084,    //此端口为任意设置,不重复即可,为 ...

  7. ADO.Net 数据库增加

    数据库增加数据其实就是把查询语句换成了增加语句,后面执行语句用操作变量点出一个执行方法 cmm.ExecuteNonQuery();//关键语句,执行CommandText,的SQL语句,增删改都用这 ...

  8. centos6 7 yum安装mongodb 3.6

    配置MongoDB的yum源 # 编辑文件 vim /etc/yum.repos.d/mongodb-org-3.6.repo # 添加以下内容 [mongodb-org-3.6] name=Mong ...

  9. node+mysql简单注册

    1前台文件 <!doctype html> <html> <head> <meta charset="UTF-8" /> <t ...

  10. linux服务不支持chkconfig的解决

    服务不支持chkconfig的解决 写了脚本,想用命令chkconfig加载自启动.提示xxxxxxx服务不支持chkconfig",原来是自己写的脚本时,忘记写两行了.开头一般要这样写 # ...