美文网首页
django学习笔记

django学习笔记

作者: 忆江南_1569 | 来源:发表于2017-05-12 15:53 被阅读45次

    django 安装

    使用pip install django即可安装django 最新版本
    查看安装的django版本
    <pre>
    import django
    django.VERSION
    输出(1, 10, 3, 'final', 0)
    </pre>
    创建一个django项目
    django-admin startproject mysite
    可以看到生成如下项目结构


    manage.py是一个命令行工具用来与项目进行交互,类似django-admin,不需要编辑
    mysite:
    init.py是一个空文件,标记mysite是一个模块
    setting.py项目的配置文件
    urls.py项目的url模式配置文件
    wsgi.py部署到正式服务器时使用
    默认生成的setting.py文件会创建一个sqllite数据库以及一个django应用列表(admin、author、message...)需要使用migrate命令在数据库中去创建这些表 Paste_Image.png

    启动开发服务器

    python3 manage.py runserver 默认启动127.0.0.1:8000端口只能本机访问
    python3 manage.py runserver 8001 指定以127.0.0.1:8001端口访问
    python3 manage.py runserver 0.0.0.0:8001 同一个网段中的机器都可以访问

    项目设置setting.py

    BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(file)))
    os.path.abspath(file)得到当前文件所在的绝对路径
    os.path.dirname返回当前文件所在的目录,不包含当前文件或当前目录
    这里的BASE_DIR为项目路径即E:/stud/mysite
    SECRET_KEY为django生成的秘钥
    DEBUG=True debug模式的开关
    ALLOWED_HOSTS设置允许哪些域名可以访问
    INSTALLED_APPS添加需要激活的应用
    MIDDLEWARE 可执行的一些中间件
    在MIDDLEWARE中加入'django.middleware.locale.LocaleMiddleware'可以设置admin后台显示为中文
    ROOT_URLCONF指明定义的主url模式存放在哪个模块
    DATABASES 数据库的相关配置

    应用

    一个项目可以有多个应用
    创建一个应用<pre>python3 manage.py startapp blog</pre>
    创建的blog应用目录结构如下


    Paste_Image.png

    migrations这个目录用来跟踪model的变化并用来同步数据库
    admin.py用来注册models,并将其加到django管理页面中
    models.py定义数据模型层
    views.py应用逻辑层,处理http请求

    models

    CharField相当与sql中的Varchar
    SlugField只能包含字母、数字、下划线和连接符的字符串,通常用于存放urls
    unique_for_date
    title = meta.CharField(maxlength=30,unique_for_date='pub_date')
    系统将不允许title和pub_date两个都相同的数据重复出现,unique_for_date的值必须为日期类型的字段
    models中的class Meta包含元数据,ordering=('-publish')表示根据数据库查询出的结果按照publish的降序排序
    str方法是当前对象的默认可读方法
    models生成的表名为应用名_类名(小写),可以通过在Meta类下指定db_table的属性来指定表名

    setting 中的INSTALLED_APPS列表用来激活创建的应用

    创建和进行数据库的迁移

    创建一个数据库迁移
    python3 manage.py makemigrations blog
    查看创建表的sql(不会执行)
    python manage.py sqlmigrate blog 0001
    运行一下命令来应用已存在的数据迁移
    python manage.py migrate

    如果使用migrate同步完数据库之后想要在models中创建的表中添加一列
    在models中添加对应的字段
    执行python3 manage.py makemigrations blog和python3 manage.py sqlmigrate blog 00X查看添加的对应字段的语句
    之后进入数据库执行数据库添加字段的命令即可
    ALTER TABLE table_name add col_name col_type default ..

    在管理站点中添加模型

    admin.site.register()

    django reverse

    django中的reverse函数的使用(可以避免在views中使用硬编码)
    return reverse('blog:post_detail',
    args=[self.publish.year,
    self.publish.strftime('%m'),
    self.publish.strftime('%d'),
    self.slug])
    url(r'^(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})/(?P<post>[-\w]+)/$',
    views.post_detail,
    name='post_detail')
    </pre>
    blog是app名,post_detail是url中配置的name名,args是url中所需的参数,用法可参考http://www.cnblogs.com/ajianbeyourself/p/4937951.html

    django中的分页pagintor

    django中自带一个分页类
    基本语法实例
    进入 python3 manage.py shell 下
    <pre>
    import os

    from django.core.paginator import Paginator
    objects = ['john','paul','george','ringo','lucy','meiry','checy','wind','flow','rain']

    p = Paginator(objects,3) # 3条数据为一页,实例化分页对象
    print p.count # 10 对象总共10个元素
    print p.num_pages # 4 对象可分4页
    print p.page_range # xrange(1, 5) 对象页的可迭代范围

    page1 = p.page(1) # 取对象的第一分页对象
    print page1.object_list # 第一分页对象的元素列表['john', 'paul', 'george']
    print page1.number # 第一分页对象的当前页值 1

    page2 = p.page(2) # 取对象的第二分页对象
    print page2.object_list # 第二分页对象的元素列表 ['ringo', 'lucy', 'meiry']
    print page2.number # 第二分页对象的当前页码值 2

    print page1.has_previous() # 第一分页对象是否有前一页 False
    print page1.has_other_pages() # 第一分页对象是否有其它页 True

    print page2.has_previous() # 第二分页对象是否有前一页 True
    print page2.has_next() # 第二分页对象是否有下一页 True
    print page2.next_page_number() # 第二分页对象下一页码的值 3
    print page2.previous_page_number() # 第二分页对象的上一页码值 1
    print page2.start_index() # 第二分页对象的元素开始索引 4
    print page2.end_index() # 第2分页对象的元素结束索引 6
    </pre>

    django models中的relate_name属性用于反向查询用,定义了一个外键时,通过外键字段查询时,此时的表名可以用relate_name的值代替,用法参考http://blog.csdn.net/lanyang123456/article/details/68962515

    django models DateTimeField中的参数auto_now默认false,设置为true时用于每次保存最后修改时间,每次都会自动保存为更新的当前时间,auto_now_add默认false,设置为True时,保存的是首次创建时间以后修改时不会再更新。用法参照http://www.cnblogs.com/dreamer-fish/p/5556641.html

    相关文章

      网友评论

          本文标题:django学习笔记

          本文链接:https://www.haomeiwen.com/subject/rtqtzttx.html