Django如何序列化和验证外部xml数据

时间:2019-01-08 13:27:19

标签: python django django-models django-rest-framework django-serializer

我有“问题”正在验证外部xml。我要从外部rss站点获取数据,验证是否存在所有字段,然后将其保存到数据库。

我遇到的问题是我不确定如何将xml数据发送到验证器。我尝试了不同的方法,但是没有用。

https://api.foxsports.com/v1/rss?partnerKey=zBaFxRyGKCfxBagJG9b8pqLyndmvo7UU&tag=nba

这是我要解析的rss的示例。

这是我的代码:

    import json
import requests
import xml.etree.ElementTree as ET

from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import status, generics

class Test(APIView):

    def get(self, request, format=None):


                response = requests.get(
                    channel.url
                )

                print(response.status_code)

                if response.status_code == 200:
                    xml = response.text.encode("utf-8")

                    tree = ET.fromstring(xml)

                    for child in tree.iter("item"):


                        serializer = RssSerializer(data=child)
                        if serializer.is_valid():
                            serializer.save(parsed_xml)

这里的问题是,无论我做什么,我的序列化器始终无效。当我编写了一个小的帮助程序功能来手动从请求中提取字段时,我就解决了这个问题。

它看起来像这样:

def parse_xml(self, node):

    parsed_json = {
        "title": node.find("title").text,
        "description": node.find("description").text,
        "link": node.find("link").text,
        "pub_date": node.find("pubDate").text,
        "guid": node.find("guid").text,
    }

    return parsed_json

基本上我只是添加了这一行parsed_xml = self.parse_xml(child) 我正在将parsed_xml发送到我的序列化器。效果很好,但对我来说似乎是一种怪诞的方式,但是我无法以任何其他方式处理数据。

 class RssSerializer(serializers.Serializer):
    title = serializers.CharField(min_length=2)
    link = serializers.CharField(min_length=2)
    description = serializers.CharField(min_length=2)
    pub_date = serializers.CharField(min_length=2)
    guid = serializers.CharField(min_length=2)


    def save(self, data):
        new_feed = RssFeed()

        new_feed.title = data["title"]
        new_feed.description = data["description"]
        new_feed.pub_date = data["pub_date"]
        new_feed.link = data["link"]
        new_feed.guid = data["guid"]

        new_feed.save()

我想知道有什么方法可以从外部来源获取xml并将其直接传递给我的验证器?预先感谢您的帮助

1 个答案:

答案 0 :(得分:1)

序列化器不希望将xml节点作为数据,因此简短的答案是“否”,不幸的是,没有直接的方法将其传递给验证器。但是,您可以重用现有方法之一,将整个xml更改为字典,然后将项目提供给序列化程序,或将单个节点更改为字典。

为了获得灵感,我将研究可用的解决方案(无需重新发明轮子):

例如您的代码可能如下所示:

xml = response.text.encode("utf-8")
xml_dict = xmltodict.parse(xml)
for item in xml_dict["rss"]["channel"]["item"]:
    serializer = RssSerializer(data=item)