====启动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. 学习opengl第一步

    有两个地址一个是学习opengl基础知识的网站, 一个是博客园大牛分享的特别好的文章. 记录一下希望向坚持做俯卧撑一样坚持下去. 学习网站:http://learnopengl-cn.readthed ...

  2. iOS app bundle id

    每个app的bundle id是唯一的,不同开发者账号不能申请相同的bundle id,例如开发者账号B想用开发者A的bundle id,只能是开发者A将这个bundle id先删除,B才可以注册,否 ...

  3. $event Object angularjs

    You can pass the $event object as an argument when calling the function. The $event object contains ...

  4. css给文字加下划线

    语法:linear-gradient(direction, color-stop 1, color-stop 2,……) 简单用法:background-image: linear-gradient( ...

  5. git 每次push都需要输入用户和密码

    git remote -v origin https://github.com/userName/xx.git (fetch) origin https://github.com/userName/x ...

  6. ETL工具总结

    ETL的考虑        做 数据仓库系统,ETL是关键的一环.说大了,ETL是数据整合解决方案,说小了,就是倒数据的工具.回忆一下工作这么些年来,处理数据迁移.转换的工作倒 还真的不少.但是那些工 ...

  7. mysql 拼接字符

    Mysql的查询结果行字段拼接,可以用下面两个函数实现: 1. concat函数 mysql> select concat('1','2','3') from test ; +--------- ...

  8. java 开学第四周

    package english; import java.io.File; import java.util.Scanner; import java.io.FileNotFoundException ...

  9. 总是Eqw

    1.投递总是Eqw状态 qstat -j job_ID #Eqw状态的job id qconf -sq all.q |grep host qconf -shgrp @allhosts

  10. 大型运输行业实战_day11_2_事务理论与实际生产配置事务管理

    1.什么是事务(Transaction:tx) 数据库的某些需要分步完成,看做是一个整体(独立的工作单元),不能分割,要么整体成功,要么整体生效.“一荣俱荣,一损俱损”,最能体现事务的思想.案例:银行 ...