Python日記——用Django做一個簡易的知乎日報API
阿新 • • 發佈:2019-01-04
現在我主要教大家如何去實戰,做一個簡易的知乎日報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%';
Variable_name | Value |
---|---|
character_set_client | utf8 |
character_set_connection | utf8 |
character_set_database | utf8 |
character_set_filesystem | binary |
character_set_results | utf8 |
character_set_server | utf8 |
character_set_system | utf8 |
character_sets_dir | /usr/share/mysql/charsets/ |
+————————–+—————————-+
對照一下結果是否是這樣
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成功後要執行的檢視函式
括號裡面有一些正則表示式,自己可以去百度搜一下怎麼寫
最後就可以把專案跑起來
效果如下