我需要制作一個 Rest API,它將接受 3 個輸入:(input_list字符串句子列表)、from_lang(字符串)、to_lang(字符串),并在從數據庫表中獲取值后返回字符串列表。例子:input - {input_list: ['how are you', 'see you later', 'where are you'], from_lang: 'english', to_lang: 'spanish' }output - {['cómo estás', 'nos vemos más tarde', 'Dónde estás']}服務將使用任何受支持語言的句子列表調用此 API,作為回報,如果數據庫中存在翻譯句子,則將獲得相同長度的列表,如果不存在,則返回 null 值。我應該如何進行?我所做的是,我創建了一個序列化器來處理/驗證傳入請求serializers.py:def supported_lang(value): if value not in SUPPORTED_LANGUAGES: print(value) print(SUPPORTED_LANGUAGES) raise serializers.ValidationError('Language not supported')class TranslateSerializer(serializers.Serializer): input_list = serializers.ListField( child=serializers.CharField(allow_blank=False), allow_empty=False ) from_language = serializers.CharField(validators=[supported_lang]) to_language = serializers.CharField(validators=[supported_lang])我定義了一個簡單的模型來存儲翻譯model.py:class TranslationModel(models.Model): english = models.CharField(blank=False, max_length=MAX_LENGTH, unique=True) spanish = models.CharField(blank=True, max_length=MAX_LENGTH) italian = models.CharField(blank=True, max_length=MAX_LENGTH) is_active = models.BooleanField(default=True)然后在我的中views.py我處理了如下的帖子請求class TranslateView(views.APIView): def post(self, request): serializer = TranslateSerializer(data=request.data) serializer.is_valid(raise_exception=True) serialized_data = serializer.validated_data result = self.get_translations(serialized_data) # here i am confused return Response(result)到目前為止一切順利,現在我很困惑如何從模型中獲取數據以及如何返回數據(遵循最佳實踐)。get_translations()我在中定義了一個函數views.py:
1 回答

慕尼黑的夜晚無繁華
TA貢獻1864條經驗 獲得超6個贊
使用 Serializers.Serializer 處理/驗證傳入請求是一個好習慣嗎
當然如此。這本質上是序列化器的核心概念之一(解析、驗證和序列化)
我是否也應該對模型使用序列化器,如果是的話如何
沒有必要這樣做。僅當從用戶發送或接收數據時才需要序列化器,但此處的情況并非如此。
如何動態傳遞過濾器值
使用字典解包
k = {request['from_language']: sentence} queryset = TranslationModel.objects.filter(**k)
添加回答
舉報
0/150
提交
取消