Django个人博客搭建教程---使用serializers序列化django对象

本文主要是介绍Django个人博客搭建教程---使用serializers序列化django对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们有一个数据表模型如下,需要将这个数据对象序列化为json格式

class Articles(models.Model):id = models.AutoField(primary_key=True)         # idtitle = models.CharField(max_length=150)        # 博客标题# body = models.TextField()  # 博客正文body = MDTextField()timestamp = models.DateTimeField()  # 创建时间authorname = models.ForeignKey('blog.BlogUser', on_delete=models.CASCADE)  # 作者姓名views = models.PositiveIntegerField(default=0)category = models.ForeignKey(Category, on_delete=models.CASCADE, primary_key=False)tags = models.ManyToManyField(Tag, blank=True, null=True)greats = models.PositiveIntegerField(default=0)comments = models.IntegerField(default=0)status = models.CharField(max_length=20, default="DEL")brief = models.CharField(max_length=200, blank=True, null=True)pic = models.ImageField(upload_to='jiablogimages')# bodypic = models.ImageField(upload_to='jiablogimages', blank=True, null=True)istop = models.CharField(max_length=5, default='', null=True, blank=True)articlebodybrief = models.TextField(blank=True, null=True)last_edit_timestamp = models.DateTimeField(auto_now=True, verbose_name="更新时间", editable=True)url_slug = models.SlugField(editable=False, max_length=200)

 

from django.core import serializers@require_http_methods(["GET"])
def show_books(request):response = {}try:articles = Articles.objects.filter(status="有效").order_by("id")response['list'] = json.loads(serializers.serialize("json", articles, ensure_ascii=False))response['msg'] = 'success'response['error_num'] = 0except Exception as e:response['msg'] = str(e)response['error_num'] = 1return HttpResponse(json.dumps(response, ensure_ascii=False))

这里没啥问题,重点是模型中使用了外键和多对多的时候,序列化无法展示完整名称

会出现这样的情况,外键和多对多关联的数据都只展示了id

{"model": "blog.articles","pk": 111,"fields": {"title": "Django个人博客搭建教程---使用Pygments和markdown实现代码高亮","body": "views.py\r\n```python\r\nimport markdown\r\nfrom markdown.extensions.toc import TocExtension\r\n \r\n \r\ndef blog_detail(request, article_id, slug):\r\n    try:\r\n        thisarticle = get_object_or_404(Articles, id=article_id, status='有效')\r\n        if thisarticle.url_slug != slug:\r\n            return render(request, '404.html')\r\n        thisarticle.increase_views()\r\n    except Exception as e:\r\n        return render(request, '404.html')\r\n    md = markdown.Markdown(extensions=[\r\n        'markdown.extensions.extra',\r\n        'markdown.extensions.codehilite',\r\n        # 'markdown.extensions.toc',\r\n        TocExtension(slugify=slugify)\r\n    ])\r\n    thisarticle.body = md.convert(thisarticle.body)\r\n    context = {\r\n        'blog': thisarticle,\r\n        'toc': md.toc,\r\n \r\n    }\r\n    return render(request, 'single.html', context=context)  # 返回info.html页面\r\n```\r\n使用Pygments生成css\r\n```\r\npygmentize -f html -a .codehilite -S tango >  tango.css \r\n```\r\n-a .codehilite指所有css选择器都具有.codehilite这一祖先选择器\r\n-S default就是指定所需要的样式了,各位可以对各种样式都尝试一下。\r\n> tango.css将内容输出到tango.css文件中\r\n\r\n关于样式,可以在python环境中查看\r\n```shell\r\nArithmetic@qingjiaowosuanshujiadeMacBook-Pro MyBlog % python3\r\nPython 3.6.6 (v3.6.6:4cf1f54eb7, Jun 26 2018, 19:50:54) \r\n[GCC 4.2.1 Compatible Apple LLVM 6.0 (clang-600.0.57)] on darwin\r\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\r\n>>> from pygments.styles import STYLE_MAP\r\n>>> STYLE_MAP.keys()\r\ndict_keys(['default', 'emacs', 'friendly', 'colorful', 'autumn', 'murphy', 'manni', 'monokai', 'perldoc', 'pastie', 'borland', 'trac', '\r\nnative', 'fruity', 'bw', 'vim', 'vs', 'tango', 'rrt', 'xcode', 'igor', 'paraiso-light', 'paraiso-dark', 'lovelace', 'algol', 'algol_nu', 'arduino',\r\n'rainbow_dash', 'abap', 'solarized-dark', 'solarized-light', 'sas', 'stata', 'stata-light', 'stata-dark', 'inkpot'])\r\n>>> \r\n```\r\n在html文件中使用css\r\n```html\r\n<link type=\"text/css\" rel=\"stylesheet\" href=\"/static/css/tango.css\">\r\n```\r\n我选择的就是tango,效果如下\r\n![](https://img-blog.csdnimg.cn/20200207175512237.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NzamRvdWRvdQ==,size_16,color_FFFFFF,t_70)","timestamp": "2020-02-16T17:09:59","authorname": 1,"views": 9,"category": 1,"greats": 0,"comments": 0,"status": "有效","brief": null,"pic": "jiablogimages/photo-1581794860915-341d339f0dde_gaitubao_800x450.jpg","istop": null,"articlebodybrief": "views.py\r\npython\r\nimport markdown\r\nfrom markdown.extensions.toc import TocExtension\r\n \r\n \r\ndef blog_detail(request, article_id, slug):\r\n    try:\r\n        thisarticle = get_object_or_404(Articles, id=a","last_edit_timestamp": "2020-02-16T17:58:55.064","url_slug": "djangoge-ren-bo-ke-da-jian-jiao-cheng-shi-yong-pygmentshe-markdownshi-xian-dai-ma-gao-liang","tags": [1,3]}
}

只要在序列化的时候加上

use_natural_foreign_keys=True

像这样

from django.core import serializers@require_http_methods(["GET"])
def show_books(request):response = {}try:articles = Articles.objects.filter(status="有效").order_by("id")response['list'] = json.loads(serializers.serialize("json", articles, use_natural_foreign_keys=True, ensure_ascii=False))response['msg'] = 'success'response['error_num'] = 0except Exception as e:response['msg'] = str(e)response['error_num'] = 1return HttpResponse(json.dumps(response, ensure_ascii=False))

 然后在对应的外键和多对多关联的数据表模型中加上

def natural_key(self):return self.__str__()

完整示例如下 

class Category(models.Model):"""Django 要求模型必须继承 models.Model 类。Category 只需要一个简单的分类名 name 就可以了。CharField 指定了分类名 name 的数据类型,CharField 是字符型,CharField 的 max_length 参数指定其最大长度,超过这个长度的分类名就不能被存入数据库。当然 Django 还为我们提供了多种其它的数据类型,如日期时间类型 DateTimeField、整数类型 IntegerField 等等。Django 内置的全部类型可查看文档:https://docs.djangoproject.com/en/1.10/ref/models/fields/#field-types"""id = models.AutoField(primary_key=True)name = models.CharField(max_length=100)def natural_key(self):return self.__str__()def catcount(self):return Articles.objects.filter(category__name__exact=self.name).filter(status='有效').count()def __str__(self):return self.nameclass Tag(models.Model):"""标签 Tag 也比较简单,和 Category 一样。再次强调一定要继承 models.Model 类!"""id = models.AutoField(primary_key=True)name = models.CharField(max_length=100)def natural_key(self):return self.__str__()def __str__(self):return self.name

 

这篇关于Django个人博客搭建教程---使用serializers序列化django对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657327

相关文章

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

对Django中时区的解读

《对Django中时区的解读》:本文主要介绍对Django中时区的解读方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景前端数据库中存储接口返回AI的解释问题:这样设置的作用答案获取当前时间(自动带时区)转换为北京时间显示总结背景设置时区为北京时间 TIM

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

java变量内存中存储的使用方式

《java变量内存中存储的使用方式》:本文主要介绍java变量内存中存储的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、变量的定义3、 变量的类型4、 变量的作用域5、 内存中的存储方式总结1、介绍在 Java 中,变量是用于存储程序中数据

关于Mybatis和JDBC的使用及区别

《关于Mybatis和JDBC的使用及区别》:本文主要介绍关于Mybatis和JDBC的使用及区别,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、JDBC1.1、流程1.2、优缺点2、MyBATis2.1、执行流程2.2、使用2.3、实现方式1、XML配置文件

macOS Sequoia 15.5 发布: 改进邮件和屏幕使用时间功能

《macOSSequoia15.5发布:改进邮件和屏幕使用时间功能》经过常规Beta测试后,新的macOSSequoia15.5现已公开发布,但重要的新功能将被保留到WWDC和... MACOS Sequoia 15.5 正式发布!本次更新为 Mac 用户带来了一系列功能强化、错误修复和安全性提升,进一步增

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg