我正在尝试Django中的BeautifulSoup4,并使用它解析了一个XML页面。当我尝试用不同的方式在python解释器中解析同一个XML页面时,它工作得很好。但是在Django中,我得到了如下所示的页面。

views.py:
def rssfeed(request):
list1=[]
xmllink="https://rss.sciencedaily.com/computers_math/computer_programming.xml"
soup=BeautifulSoup(urlopen(xmllink),'xml')
for items in soup.find_all('item'):
list1.append(items.title)
context={
"list1":list1
}
return render(request,'poll/rssfeed.html',context)rssfeed.html:
{% if list1 %}
<ul>
{% for item in list1 %}
<li>{{ item }}</li>
{% endfor %}
</ul>
{% endif %}我做错什么了?
发布于 2016-09-19 17:07:07
要从XML获取文本,需要调用get_text()函数。
不要使用:
items.title使用:
items.title.get_text()此外,建议使用lxml进行解析。安装lxml python并使用:
soup = BeautifulSoup(urlopen(xmllink), 'lxml-xml')发布于 2016-09-19 04:14:16
来自文档
如果变量的任何部分是可调用的,模板系统将尝试调用它。
和
有时,出于其他原因,您可能希望关闭此特性,并告诉模板系统无论如何都要保留一个未调用的变量。为此,请在可调用的值True上设置一个do_not_call_in_templates属性。
调用标记就像调用find_all()
例如:tagX('a')返回在此tagX中找到的所有<a>标记的列表。
模板中的item引用了可调用的bs4.element.Tag实例。因此Django使用零参数调用item变量,这意味着它将返回item中所有元素的列表,该列表为none,因为它只包含文本。因此出现了空白列表。
因此,要么在将上下文传递给模板之前解析它
list1 = [item.title.text for item in soup.find_all('item')]或者,如果出于某种原因要传递实例,可以将do_not_call_in_templates属性设置为
for item in soup.find_all('item'):
title = item.title
title.do_not_call_in_templates = True
list1.append(title)https://stackoverflow.com/questions/39564141
复制相似问题