Python采用Django制作简易的知乎日报API
作者:qq_32198277 发布时间:2023-10-07 13:02:34
现在我主要教大家如何去实战,做一个简易的知乎日报API
首先你要熟悉django的基本用法,会写模型,会写视图函数,会配置url。
1.配置字符编码
因为我们等一下要使用中文,所以要先设好字符编码
在settings.py里将LANGUAGE_CODE设为'zh-CN'
然后添加这两行
FILE_CHARSET='utf-8'
DEFAULT_CHARSET='utf-8'
还要进入到数据库
依次输入
set character_set_client=utf8 ;
set character_set_connection=utf8 ;
set character_set_database=utf8 ;
set character_set_results=utf8 ;
set character_set_server=utf8 ;
set character_set_system=utf8 ;
设置完成之后,输入
show variables like 'character%';
对照一下结果是否是这样
2.然后开始写模型
class News(models.Model):
created = models.DateTimeField(auto_now_add=True)
title = models.CharField(max_length=100)
image = models.CharField(max_length=100)
theme_id =models.IntegerField()
class Meta:
ordering = ('created',)
def __unicode__(self):
return self.title
class NewsDetail(models.Model):
news = models.ForeignKey(News)
created = models.DateTimeField(auto_now_add=True)
content = models.CharField(max_length=1000)
image = models.CharField(max_length=99)
class Meta:
ordering = ('created',)
def __unicode__(self):
return self.news.title
这里不难理解,这里我分两层,第一层是概括,第二层是详细内容,然后以概括的作为外键
概括主要包含标题,配图地址和主题
详细内容包括内容和配图地址
3.将模式序列化
这是rest_framework非常强大的一点
在app里新建一个serializers.py,然后创建继承自ModelSerializer的类
from rest_framework import serializers
class NewsSerializer(serializers.ModelSerializer):
class Meta:
model = News
fields = ('id', 'title', 'image', 'theme_id')
class NewsDetailSerializer(serializers.ModelSerializer):
class Meta:
model = NewsDetail
fields = ('id', 'image', 'content')
model为模型,fields为你想要查询显示的字段
4.然后再写视图函数
rest_framework.renderers中的JSONRenderer可以将对象渲染为json形式的字符串
from rest_framework.renderers import JSONRenderer
class JSONResponse(HttpResponse):
"""
用于返回JSON数据.
"""
def __init__(self, data, **kwargs):
content = JSONRenderer().render(data)
kwargs['content_type'] = 'application/json'
content='{"news":'+content+'}'
super(JSONResponse, self).__init__(content, **kwargs)
我们在字符串外面在包一个news,这样获取比较方便
如何像知乎日报的那样获取最新的几个news呢
@csrf_exempt
def latest_news(request):
"""
展示最新的10个news.
"""
if request.method == 'GET':
news = News.objects.all()[:10]
serializer = NewsSerializer(news, many=True)
return JSONResponse(serializer.data)
因为返回的是一个集合所以NewsSerializer的many参数要设为True
返回某个主题的前几个news
@csrf_exempt
def theme_news(request,theme_id):
"""
展示某个主题的前10个news.
"""
if request.method == 'GET':
news=News.objects.filter(theme_id=theme_id)[:10]
serializer = NewsSerializer(news, many=True)
return JSONResponse(serializer.data)
返回某个id的news的详细内容
@csrf_exempt
def news_detail(request,news_id):
"""
显示某个news的内容.
"""
try:
news = NewsDetail.objects.get(news_id=news_id)
except Snippet.DoesNotExist:
return HttpResponse(status=404)
if request.method == 'GET':
serializer = NewsDetailSerializer(news)
# print serializer.data
return JSONResponse(serializer.data)
这里获取的是单个对象所以不用加many参数
5.配置url
urlpatterns = [
...
url(r'^api/4/news/latest$', latest_news),
url(r'^api/4/news/theme/(?P<theme_id>[0-9]+)/$', theme_news),
url(r'^api/4/news/(?P<news_id>[0-9]+)/$', news_detail),
]
括号包住的是要传入的参数,逗号后面的是匹配url成功后要执行的视图函数
括号里面有一些正则表达式,自己可以去百度搜一下怎么写
最后就可以把项目跑起来
效果如下


猜你喜欢
- 本文实例讲述了GO语言实现简单TCP服务的方法。分享给大家供大家参考。具体实现方法如下:package mainimport ("
- 通用用法但上图的字段名,类型需要根据不同接口填写,如某服务接口:因而对应的上传代码如下:# 输出参数:请求响应报文import reques
- 安装Apache1.安装yum -y install httpd2.开启apache服务systemctl start httpd.serv
- 利用Keras构建完普通BP神经网络后,还要会构建CNNKeras中构建CNN的重要函数1、Conv2DConv2D用于在CNN中构建卷积层
- 【OpenCV】⚠️高手勿入! 半小时学会基本操作⚠️色彩空间概述OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天
- 一般跟踪训练的ground_truth的数据保存在文本文文件中,故每一行的数据为一张图片的标签数据,这个时候读取每一张图片的标签,具体实现如
- 1.怎么样查看数据库字符集 [A]数据库服务器字符集select * from nls_database_parameters,其来源于pr
- 1. 为什么需要Simhash?传统相似度算法:文本相似度的计算,一般使用向量空间模型(VSM),先对文本分词,提取特征,根据特征建立文本向
- 写了个简洁的隔行变色代码,支持三种动作变化颜色<!DOCTYPE html PUBLIC "-//W3C//DTD XHTM
- 这几天无聊的很看着china.nba.com焦点图效果捣鼓了一下有待完善!兼容性:IE6 , IE7 &nb
- 我们知道numpy.ndarray.reshape()是用来改变numpy数组的形状的,但是它的参数会有一些特殊的用法,这里我们进一步说明一
- 1.前言数据展示,即数据可视化,是数据分析的第五个步骤,大部分人对图形敏感度高于数字,好的数据展示方式能让人快速发现问题或规律,找到数据背后
- 目录一、MySQL的join buffer二、join buffer cache存储空间的分配三、普通的多表查询实现四、join buffe
- 如下所示:'''@author: Jacobpc'''import osimport sys
- --------------------------------------------------------- 正则收藏 手机号码: $
- 假设我们需要从各种网页中提取全文,并且要剥离所有HTML标记。通常,默认解决方案是使用BeautifulSoup软件包中的get_text方
- 本文作者在和同事的一次讨论中发现,对 IntelliJ IDEA 内存采用不同的设置方案,会对 IDE 的速度和响应能力产生不同的影响。Do
- 本文实例讲述了Python基于回溯法子集树模板实现图的遍历功能。分享给大家供大家参考,具体如下:问题一个图:A --> BA --&g
- 系统环境:win10 开发环境:JetBrains PyCharm 2017.1.5 x64 Python版本:2.7假如我们有一个clas
- [项目]数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除![分析]1、生成一