参考文档:

http://www.cnblogs.com/fnng/p/4373108.html

https://code.ziqiangxuetang.com/django/django-intro.html

Django的学习已经丢了很长一段时间了,时值年底,基本工作都差不多了,准备重新捡起来。

学习心得也会有空mark一下!

准备作业:让我们一览 Django 全貌

urls.py
网址入口,关联到对应的views.py中的一个函数(或者generic类),访问网址就对应一个函数。

views.py
处理用户发出的请求,从urls.py中对应过来, 通过渲染templates中的网页可以将显示内容,比如登陆后的用户名,用户请求的数据,输出到网页。

models.py
与数据库操作相关,存入或读取数据时用到这个,当然用不到数据库的时候 你可以不使用。

forms.py
表单,用户在浏览器上输入数据提交,对数据的验证工作以及输入框的生成等工作,当然你也可以不使用。

templates 文件夹

views.py 中的函数渲染templates中的Html模板,得到动态内容的网页,当然可以用缓存来提高速度。

admin.py
后台,可以用很少量的代码就拥有一个强大的后台。

settings.py
Django 的设置,配置文件,比如 DEBUG 的开关,静态文件的位置等。

言归正传,本次主要解决的问题是,通过Django框架将数据库里面的字段显示到前台页面上:

  1. models.py里新建相关表_Author
  2. views.py提供数据查询及返回相关结果_result
  3. urls.py指定相关跳转链接
  4. templates/app/query.html 负责处理views.py的返回值及渲染显示结果
#models.py
from django.db import models # Create your models here. class Author(models.Model):
name=models.CharField(u'姓名',max_length=50)
qq=models.CharField(max_length=10)
addr=models.TextField()
email=models.EmailField() def __str__(self):
return self.name
#views.py
from app.models import Author def query(request):
#result=Author.objects.all()
result=Author.objects.values_list() #返回数据库查询结果(sql:select * from Author ),list类型, assert isinstance(request, HttpRequest)
return render(
request,
'app/query.html',
{
'title':'Query', #将查询结果渲染到app/query.html的变量result中
'result':result,
'year':datetime.now().year,
} )
#urls.py

import app.views

urlpatterns = [
# Examples: url(r'^admin/', admin.site.urls,name='admin'),
url(r'^query/', app.views.query,name='query'),
#templates\app\query.html

<table   class="table table-hover"> #引用bootstrap表格样式
<caption> Result of Query </caption>
#遍历循环赋值
{% for i in result %}
<tr>
{% for j in i %}
<td>{{ j }}</td>
{% endfor %}
</tr>
{% endfor %}
</table> {% endblock %}

一切ok的话,启动服务器,结果如下:

但是这里有一个问题,我在views.py里面使用的result=Author.objects.values_list() ,是把该表的所有数据都取出来了。如果现在只想取某几个字段的数据(不想要ID字段),目前我的能力有两种方法解决:

1、views.py里面直接查询我想要的字段:

result=Author.objects.values_list('name','qq','addr','email')

结果对比,可以在django shell里面看到:

>>> print (str(Author.objects.values_list().query))
SELECT "app_author"."id", "app_author"."name", "app_author"."qq", "app_author"."
addr", "app_author"."email" FROM "app_author"
>>> print (str(Author.objects.values_list('name','qq','addr','email').query))
SELECT "app_author"."name", "app_author"."qq", "app_author"."addr", "app_author"
."email" FROM "app_author"

页面显示效果:

2、views.py里查询条件不变,更改urls里的循环条件,即不输出查询结果列表里面第一个数据(ID字段):

(模板里列表索引取值为 i.n,而不是python里面的i[1])

<table   class="table table-hover">
<caption> Result of Query </caption> {% for i in result %}
<tr>
<td>{{ i.1 }}</td>
<td>{{ i.2 }}</td>
<td>{{ i.3 }}</td>
<td>{{ i.4 }}</td>
</tr>
{% endfor %}
</table>

页面显示效果:

美观一下,加上列标题:

<table   class="table table-hover">
<caption> Result of Query </caption>
<tr>
{#<td> ID </td>#}
<td> NAME </td>
<td> QQ </td>
<td> ADD </td>
<td> MAIL </td>
</tr>
{% for i in result %}
<tr>
<td>{{ i.1 }}</td>
<td>{{ i.2 }}</td>
<td>{{ i.3 }}</td>
<td>{{ i.4 }}</td>
</tr>
{% endfor %}
</table>

完工!

Tips:

Django 模板查找机制: Django 查找模板的过程是在每个 app 的 templates 文件夹中找(而不只是当前 app 中的代码只在当前的 app 的 templates 文件夹中找)。各个 app 的 templates 形成一个文件夹列表,Django 遍历这个列表,一个个文件夹进行查找,当在某一个文件夹找到的时候就停止,所有的都遍历完了还找不到指定的模板的时候就是 Template Not Found (过程类似于Python找包)。这样设计有利当然也有弊,有利是的地方是一个app可以用另一个app的模板文件,弊是有可能会找错了。所以我们使用的时候在 templates 中建立一个 app 同名的文件夹,这样就好了。

这就需要把每个app中的 templates 文件夹中再建一个 app 的名称,仅和该app相关的模板放在 app/templates/app/ 目录下面

最新文章

  1. (八)Eclipse创建Maven项目运行mvn命令
  2. Ubuntu 16.04 LTS发布
  3. 推荐《HeadFirst设计模式》
  4. ubuntu-E:Encountered a section with no Package: header的解决办法
  5. delphi TFileStream.create
  6. 函数buf_page_init
  7. 日文“表” php 会报错
  8. 使用 Gradle 实现 TFS 构建自动化
  9. HDU-4570 Multi-bit Trie
  10. java dom4j解析xml实例(3)
  11. Maven-常用插件
  12. 杭电ACM2008--数值统计
  13. 照葫芦画瓢系列之Java --- eclipse下使用maven创建Struts 2项目
  14. 将labelme 生成的.json文件进行可视化的代码+label.png 对比度处理的matlab代码
  15. MySQL中MyISAM和InnoDB两种主流存储引擎的特点
  16. 64-65管道,rm与rmdir
  17. Scala之隐式转换implicit详解
  18. docker 查看容器的网络连接
  19. linux基础命令之sed
  20. linux系统UDP的socket通信编程

热门文章

  1. Centos 7 安装 PostgreSQL
  2. 让你用sublime写出最完美的python代码--windows环境
  3. IntelliJ IDEA 左侧列表设置忽略文件格式
  4. WebUploader上传文件(一)
  5. PL/SQL Developer使用技巧(部分)
  6. Data Base mongodb driver2.5环境注意事项
  7. iOS 字体设置,字体类型展示
  8. python访问http的GET/POST
  9. LAMP第二部分apache配置
  10. IDE 、SATA、SCSI 的区别