前言】中型的项目是比较多的APP,肯会涉及多数据表的操作。如果有人带那就最好了,自己要先了解基本的django框架(MTV ,ORM等)师傅可以给讲解一下框架怎么组织url.py,model.py,admin.py,view.py,.html顺序的,弄懂一个app。其他的也就触类旁通了。由于使用的django框架公司没人用过,将自己摸索学习的过程记录一下。

一、工程项目介绍

1、一个erp管理系统,41个文件目录,190个文件,还算是一个中型的项目。好在里面的APP有相似的,无需全部搞懂所有的,只需搞懂那么一个,触类旁通。

新手怎么读懂一个中型的Django项目_qt
2、运行界面

新手怎么读懂一个中型的Django项目_Python_02

二、先看一个完整的从请求到响应

网上一张完整的图:

新手怎么读懂一个中型的Django项目_qt_03
大致几个步骤:

1. 用户通过浏览器请求一个页面 
2. 请求到达Request Middlewares,中间件对request做一些预处理或者直接response请求 
3. URLConf通过urls.py文件和请求的URL找到相应的View 
4. View Middlewares被访问,它同样可以对request做一些处理或者直接返回response 
5. 调用View中的函数 
6. View中的方法可以选择性的通过Models访问底层的数据 
7. 所有的Model-to-DB的交互都是通过manager完成的 
8. 如果需要,Views可以使用一个特殊的Context 
9. Context被传给Template用来生成页面 
    a.Template使用Filters和Tags去渲染输出 
    b.输出被返回到View 
    c.HTTPResponse被发送到Response Middlewares 
    d.任何Response Middlewares都可以丰富response或者返回一个完全不同的response 
    e.Response返回到浏览器,呈现给用户    

三、正式分析

分析的前提,默认已经设置好所有的数据库,可以运行工程,就差读懂代码。

wsgi到中间件就略过了,我们分析主要的程序!!

1、先找到seting.py所在的目录

新手怎么读懂一个中型的Django项目_Python_04

2、打开url.py

新手怎么读懂一个中型的Django项目_Python_05

可以看到,有初始的admin对应的view,后面两个是分APP所在的目录对应的url.py,所以url.py不止一处。

3、打开workflow.view.start函数

view里面的函数都是对数据库的操作,是对数据的承上启下作用,我们看箭头指的那个表Modal(models.py里面的类)
新手怎么读懂一个中型的Django项目_Python_06
4、在view.py的同级目录下,找到admin.py

这里他进行了Mddal类的绑定:

新手怎么读懂一个中型的Django项目_qt_07

找到后面那个绿色区域的类,那里就是web后台。django自带的后台管理。所谓后台,就是对model.py里面定义的数据库字段,进行前台显示。

新手怎么读懂一个中型的Django项目_Python_08

5、我们找到modal所在的models.py,这里面是对数据库中字段的定义,“=”左边是数据库中的字段名,右边“workflow code”是可以自己命名的,将显示在前端。可以命名成汉字。打开:

新手怎么读懂一个中型的Django项目_qt_09
里面是对列的定义。类名就是表名,类里面的字段代表数据表中的字段(code),数据类型则由CharField(相当于varchar)、DateField(相当于datetime), max_length 参数限定长度。

其对应的数据库里面的字段:

新手怎么读懂一个中型的Django项目_qt_10
6、如此,我们的代码和数据库交互了起来,我们可以在view()中对数据库进行增删改查,view()中还要负责将数据映射到html文件中,html再动态链接css渲染,输出到界面。注意,我们的分析过程并不是一条直线,在view()处分成了两路。view()往下的我们分析过了,下面分析view()往上到达html的。

7、还是回到view.py,找到start函数,在类的最后我们看到了类的调用:
新手怎么读懂一个中型的Django项目_qt_11
调用了.html文件

8、html文件里面包含太多继承,除了base.html可以看懂,其他的我基本看不懂。那咋办呢?——我一般是打开对应的网页,然后看网页源码,这样将源码和其对应的html文件对比,也能明白个差不多。

html语言弄懂标签就简单了。

四、实战一个例子

1、basedata中的model.py

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,
互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
class ExpenseAccount(generic.BO):
    """
    基金账户
    """
    index_weight = 10
    status= models.CharField(_("基金ID"),max_length=const.DB_CHAR_NAME_120)
    qhzh = models.CharField(_("期货账户"),max_length=const.DB_CHAR_NAME_120)
    code = models.CharField(_("期货入金"),max_length=const.DB_CHAR_NAME_20,blank=True,null=True)
    yhzh = models.CharField(_("银行账户"),max_length=const.DB_CHAR_NAME_120)
    name = models.CharField(_("银行入金"),max_length=const.DB_CHAR_NAME_120)

    description = models.TextField(_("备注"),blank=True,null=True)
    parent = models.ForeignKey('self',verbose_name=_("parent"),null=True,blank=True)

    class Meta:
        verbose_name = _('expenses account')
        verbose_name_plural = _('基金账户')
        #对记录的排序,两个是二级排序
        ordering = ['-modification','status']

2、admin.py

class ExpenseAdmin(generic.BOAdmin):

    list_display = ['status','qhzh','code','yhzh','name','modification','description']
    list_display_links = ['code','name']
    search_fields = ['name']

五、小结

django框架是比其他框架复杂一些,基于mvt架构理论理清其中url,models,view,admin,html几者的关系就简单了。在复杂一些的django项目,也就是增加了APP的数量。当然此时会涉及更多的框架之外的知识,比如数据库表的一对多等等。需要多看,多学习吧!我又浅尝辄止了……