我有“问题”正在验证外部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并将其直接传递给我的验证器?预先感谢您的帮助
答案 0 :(得分:1)
序列化器不希望将xml节点作为数据,因此简短的答案是“否”,不幸的是,没有直接的方法将其传递给验证器。但是,您可以重用现有方法之一,将整个xml更改为字典,然后将项目提供给序列化程序,或将单个节点更改为字典。
为了获得灵感,我将研究可用的解决方案(无需重新发明轮子):
此问题已经解决How to convert an xml string to a dictionary in Python?
我曾经使用此DRF XML解析器来解析XML请求,并且它完成了工作:https://github.com/jpadilla/django-rest-framework-xml/blob/master/rest_framework_xml/parsers.py#L40
,如果您不介意其他库,那么xmltodict也为我完成了类似的工作https://docs.python-guide.org/scenarios/xml/
例如您的代码可能如下所示:
xml = response.text.encode("utf-8")
xml_dict = xmltodict.parse(xml)
for item in xml_dict["rss"]["channel"]["item"]:
serializer = RssSerializer(data=item)