首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用python搭建一个校园维基网站(二)—— 可编辑内容的首页的创建

还包含了一个wagtail提供的对ForeignKey进行了一层封装的ParentalKey外键连接到它所属的WikiHome页面。类似的,panels表明出现在可编辑区。 ? ?...WikiHomeTopLink类似,为了层次上更清晰,采用了多重继承,在models.py中只定义ParentalKey外键,而在另一个文件中定义了RelatedLink模型,包含的字段有链接文本和具体链接...,只是具体链接可能为外链、某个页面或某个文档,占用了三个字段,此外还利用@property装饰器为该模型添加了link属性,来返回它的具体链接,这样在模板中就可以使用.link调用。...对于模板来说,它对应的页面模型处于它的上下文环境,在模板中可以调用到该页面模型中的所有元素(使用Django的模板语言)。我们要按照页面排版将元素填充进去。...考虑到页脚的内容一般比较固定,我们使用snippets和模板标签tag的形式来实现。

3.6K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【愚公系列】2022年01月 Python教学课程 40-Django框架之模型属性详解

    定义属性时需要指定字段类型,通过字段类型的参数指定选项,语法如下: 属性=models.字段类型(选项) 4)字段类型 类型 说明 AutoField 自动增长的IntegerField,通常不用指定,...不指定时Django会自动创建属性名为id的自动增长属性 BooleanField 布尔字段,值为True或False NullBooleanField 支持Null、True、False三种值 CharField...默认值是False db_column 字段的名称,如果未指定,则使用属性的名称 db_index 若值为True, 则在表中会为此字段创建索引,默认值是False default 默认 primary_key...异常 二、模型类迁移 将模型类同步到数据库中。...1)生成迁移文件 python manage.py makemigrations 2)同步到数据库中 python manage.py migrate 总结 django开发模型类和字段最好在代码里定义在迁移同步到数据库

    1.4K20

    Django之model改update用法介绍

    username='nick' where id = 1 方法二适合更新一条数据,也只能更新一条数据,当只有一条数据更新时推荐使用此方法,另外此方法还有一个好处,我们接着往下看 具有auto_now属性字段的更新...,用来标识这条记录的创建时间,具有auto_now_add属性,创建记录时会自动填充当前时间到此字段 - 修改时间,用来标识这条记录最后一次的修改时间,具有auto_now属性,当记录发生变化时填充当前时间到此字段...verbose_name='激活状态') 当表有字段具有auto_now属性且你希望他能自动更新时,必须使用上边方法二的更新,不然auto_now字段不会更新,也就是: _t = User.objects.get...json型,那么如何用最少的代码方便的更新json格式数据到数据库呢?...{'username':'nick','is_active':'0'} User.objects.filter(id=1).update(**data) 同样这种方法不能自动更新具有auto_now属性字段的值

    76910

    Django model update的各种用法介绍

    username='nick' where id = 1 方法二适合更新一条数据,也只能更新一条数据,当只有一条数据更新时推荐使用此方法,另外此方法还有一个好处,我们接着往下看 具有auto_now属性字段的更新...,具有auto_now_add属性,创建记录时会自动填充当前时间到此字段 修改时间,用来标识这条记录最后一次的修改时间,具有auto_now属性,当记录发生变化时填充当前时间到此字段 就像下边这样的表结构...verbose_name='激活状态') 当表有字段具有auto_now属性且你希望他能自动更新时,必须使用上边方法二的更新,不然auto_now字段不会更新,也就是: _t = User.objects.get...jason型,那么如何用最少的代码方便的更新json格式数据到数据库呢?...{'username':'nick','is_active':'0'} User.objects.filter(id=1).update(**data) 同样这种方法不能自动更新具有auto_now属性字段的值

    5.7K20

    Django中的关系映射

    级联删除的特殊字段 models.CASCADE:Django模拟SQL约束ON DELETE CASCADE,并删除包含ForeignKey的对象 注意该CASCADE会有限查找是否有关联数据,先删除管理数据...class UserMit(models.Model): # id创建为UUID类型,字段命名为user_id id = models.UUIDField(primary_key=True...# 通过外键绑定的users_id查询用户,接着上面的创建数据来 >>> a2.id 6 >>> a2.users_id UUID('43ff679f-42b2-4334-85a0-b493503d6433...') 反向查询 没有外键属性的一方,可以调用反向属性查询到关联的另一方 反向关联的属性为实例对象.引用类名(小写) 当反向引用不存在的时候,则会触发异常 当UserId类中定义了外键约束...,必须传入class对象 Students.objects.create(student_name="Liyang",classroom_id=1) # 对应外键值属性字段,必须传入具体的值 一对多(

    1.7K20

    ​第 07 篇:创作后台开启,请开始你的表演!

    要修改 app 在 admin 后台的显示名字,添加 verbose_name 属性。...此前我们在 blog/admin.py 中定义了一个 PostAdmin 来配置 Post 在 admin 后台的一些展现形式。list_display 属性控制 Post 列表页展示的字段。...此外还有一个 fields 属性,则用来控制表单展现的字段,正好符合我们的需求: class PostAdmin(admin.ModelAdmin): list_display = ['title...django admin 已经自动帮我们生成了),而如果用户登录了我们的站点,那么 django 就会将这个用户实例绑定到 request.user 属性上,我们可以通过 request.user 取到当前请求用户...这个方法接收四个参数,其中前两个,一个是 request,即此次的 HTTP 请求对象,第二个是 obj,即此次创建的关联对象的实例,于是通过复写此方法,就可以将 request.user 关联到创建的

    1.1K20

    Django——ContentType(与多个表建立外键关系)及ContentType-signals的使用

    想要记录下每个操作,同时还能追踪到这个操作的具体动作。   *首先用信号机制,监听信号,实现对信号的响应函数,在响应函数中记录发生的动作(记录在一张记录表,相当于下文的Event)。   ...*其次就是为了能追踪到操作的具体动作,必须从这张表中得到相应操作的model,这就得用到上面说的ContentType。   ...怎么从这张操作记录表中得到相应操作的model呢,这就得用到fields.GenericForeignKey,它是一个特殊的外键,可以指向任何Model的实例,在这里就可以通过这个字段来指向类似Post...创建事件的时候看到可以将post这个instance直接赋给generic.GenericForeignKey类型的字段,从而event实例就可以通过它来获取事件的真正信息了。   ...ForeignKey 字段到ContentType.

    4.4K20

    django models.py(python和django)

    文章目录 1.创建模型类 2.shell工具增删改查 2.1增 2.2修改 2.3删除 2.4查询 2.5比较属性 2.6sql中的and、or 2.7mysql的聚合函数 2.8mysql中的排序 2.9...2) 关于主键 django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...默认创建的主键列属性为id,可以使用pk代替,pk全拼为primary key。...__gt='2021-10-01') 2.5比较属性 为了方便测试为goods表添加总数量跟库存 为实体类添加字段 quantity = models.IntegerField(default=0, verbose_name...同步到数据库中 python manage.py migrate 查询总数量大于库存的商品 2.6sql中的and、or 2.7mysql的聚合函数 使用aggregate()过滤器调用聚合函数。

    1.1K10

    零基础使用Django2.0.1打造在线教育网站(五):简易留言簿交互实现

    将后台数据展示到前端页面 我们这里假定已经在数据库中已经存有一些数据(实际上就是前面已经存入的数据),如果存在一个叫newbee的人,就直接将他的数据修改回填到我们的HTML页面上来;如果没有就直接添加这个人的信息... 并将value的值修改为value="{{ my_message.name }}",其他的几个属性也是类似,这里就不细说了...Django模板语言 如果你有编程背景或者您之前使用过一些在HTML中直接插入程序代码的语言,那么现在你需要记住,Django的模版系统并不是简单的将Python嵌入到HTML中(事实上,Django不允许我们在...,它将以这样的顺序查询: 字典查询(Dictionary lookup) 属性或方法查询(Attribute or method lookup) 数字索引查询(Numeric index lookup)...标签比变量复杂得多:有些用于在输出中创建文本,有些用于控制循环或逻辑,有些用于加载外部信息到模板中供以后的变量使用。

    1.4K80

    在线网站搭建(七):数据库字段的定义(上)

    6 、全局变量尽量只在模块内有效,类似C语言中的static。实现方法有两种,一是all机制;二是前缀一个下划线。 7 、函数命名使用全部小写的方式,可以使用下划线。...10、类的属性有3种作用域public、non-public和subclass API,可以理解成C++中的public、private、protected,non-public属性前,前缀一条下划线。...11 、类的属性若与关键字名字冲突,后缀一下划线,尽量不要使用缩略等其他方式。 12 、为避免与子类属性命名冲突,在类的一些属性前,前缀两条下划线。比如:类Foo中声明__a,访问时,只能通过Foo....(五)编码的建议 1、编码中考虑到其他python实现的效率等问题,比如运算符‘+’在CPython(Python)中效率很高,都是Jython中却非常低,所以应该采用.join()的方式。...3 、使用基于类的异常,每个模块或包都有自己的异常类,此异常类继承自Exception。 4 、异常中不要使用裸露的except,except后跟具体的exceptions。

    90120

    1.4 Django基础篇--数据库模型设计

    2.标签和分类类似,如下所示,博客有很多标签标记文章的主题,标签需要作为单独的数据表,里面需要存储标签的id和名称 ?...其实这在数据库设计中很常见,描述两个表多对多的关系时,会生成一个中间表,将多对多的关系转化为两个表和中间表一对多的关系,这样可以使用外键将表联系起来。...由于通过ORM的方式,因此在models中一个类即是一个数据表,一个属性对应着数据表中的字段。...models.CharField类的的初始化参数max_length代表着这存储数据的最大长度,verbose_name用来对name属性进行描述,在界面显示时有用。...经过以上的分析,数据模型基本上建立起来了,不过这还没有结束,因为 还没有完成模型到真实数据库的迁移。接下来要做的是配置数据库,完成代码到数据库的“翻译”。

    1.3K30

    几乎不写一行代码,快速开发后台功能

    逻辑模型设计:将业务需求具体化,实现具体业务场景所描述的东西。比如,用户信息包括用户姓名、性别和联系电话等属性,一个商品分类可以有0个、1个或多个商品。...物理模型设计:针对逻辑模型分析的内容,在具体的物理介质上实现出来。比如,在MySQL数据库中编写SQL脚本建立用户信息表。 从逻辑模型到物理模型,是一个从抽象到具体、不断细化完善的过程。...inspectdb > models.py #输出到models.py文件中 当数据表中字段很多时,反向生成模型可以提高模型的编写效率。...(1)自定义一个继承自ModelAdmin的类。该类用来在Admin后台管理系统中显示模型。 (2)使用装饰器将模型类Goods和GoodsAdmin关联起来,并注册到Admin后台管理系统中。...admin.py用于将项目应用定义的模型独享注册,并绑定到Admin后台管理系统中。注册后,Admin后台管理系统自动拥有了该模型对应数据表的增加、删除、修改和查询功能。

    98220

    drf序列化器之反序列化的数据验证

    使用序列化器进行反序列化时,需要对数据进行验证后,才能获取验证成功的数据或保存成模型类对象。...验证失败,可以通过序列化器对象的errors属性获取错误信息,返回字典,包含了字段和字段的错误提示。...验证成功,可以通过序列化器对象的validated_data属性获取数据。 在定义序列化器时,指明每个字段的序列化类型和选项参数,本身就是一种验证行为。...validate, 参数data代表了所有字段的数据值,其实就是视图代码中实例化序列化器对象时的data参数 开发中,类似 密码和确认密码,此时这2个字段,必须进行比较才能通过验证...5、validators验证器验证 验证器类似于验证方法,但是验证方法只属于当前序列化器,如果有多个序列化器共用同样的验证功能,则可以把验证代码分离到序列化器外部,作为一个普通函数,由validators

    2.1K30

    【Python全栈100天学习笔记】Day41 Django深入理解框架

    字段属性primary_key用于设置主键,max_length用来设置字段的最大长度,db_column用来设置数据库中与字段对应的列,verbose_name则设置了Django后台管理系统中该字段显示的名称...如果不希望执行反向查询可以将related_name属性设置为'+'或以'+'开头的字符串。...存储URL的CharField UUIDField 存储全局唯一标识符 字段属性 通用字段属性 选项 说明 null 数据库中对应的字段是否允许为NULL,默认为False blank 后台模型管理验证数据时...primary_key 将字段指定为模型的主键,未指定时会自动添加AutoField用于主键,只读。...unique 设置为True时,表中字段的值必须是唯一的 verbose_name 字段在后台模型管理显示的名称,未指定时使用字段的名称 ForeignKey属性 limit_choices_to:值是一个

    2.3K30

    Django模型

    (max_length=128, verbose_name='名称') # 类的属性就是数据表中的字段。...默认创建的主键列属性为id,也可以使用pk,意为primary key. 字段名称中不能出现双下划线,因为这是Django的查询语法之一。...下面是Django中常用的字段类型的详情 字段类型 类型 说明 BigAutoField 自动增长的BigIntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性...db_column 字段的名称,如果未指定,则使用属性的名称 db_index 若值为True, 则在表中会为此字段创建索引,默认值是False default 为字段指定默认值 primary_key...choices参数就是从我们定义的二元组(GENDER_CHOICES)中获取值。二元组的第一个值会储存在数据库中,而第二个值将只会用于在表单中显示。

    1.9K20

    Django 2 DateTimeField格式 在程序中手动赋值

    需要注意的是,设置该参数为true时,并不简单地意味着字段的默认值为当前时间,而是指字段会被“强制”更新到当前时间,你无法程序中手动为字段赋值;如果使用django再带的admin管理器,那么该字段在admin...DateTimeField.auto_now_add 这个参数的默认值也为False,设置为True时,会在model对象第一次被创建时,将字段的值设置为创建时的时间,以后修改对象时,字段的值不会再更新...该属性通常被用在存储“创建时间”的场景下。与auto_now类似,auto_now_add也具有强制性,一旦被设置为True,就无法在程序中手动为字段赋值,在admin中字段也会成为只读的。...赋值的方法 其实DateTimeField字段对应的就是Python里的datetime.datetime,也可以使用django.utils.timezone.now() 的方法来进行时间设置。...下面来写一个示例,分别用这两个方法来赋值一下自定义的时间字段。

    3.2K10
    领券