如何使用 rometools 正确解析 RSS XML?
how to correctly parse RSS XML with rometools?
我正在尝试用 rometools
解析 RSS XML 文件,但我无法让它工作。下面的 Product
class 包含来自以下 RSS XML 文件的所有元素。但我似乎无法将文件正确映射到实体。
RSS XML 文件:
<?xml version="1.0"?>
<rss xmlns:g="http://base.google.com/ns/1.0" version="2.0">
<channel>
<title>Test Store</title>
<link>http://www.example.com</link>
<description>An example item from the feed</description>
<item>
<g:id>DB_1</g:id>
<g:title>Dog Bowl In Blue</g:title>
<g:description>Solid plastic Dog Bowl in marine blue color</g:description>
<g:link>http://www.example.com/bowls/db-1.html</g:link>
<g:image_link>http://images.example.com/DB_1.png</g:image_link>
<g:brand>Example</g:brand>
<g:condition>new</g:condition>
<g:availability>in stock</g:availability>
<g:price>9.99 GBP</g:price>
<g:shipping>
<g:country>UK</g:country>
<g:service>Standard</g:service>
<g:price>4.95 GBP</g:price>
</g:shipping>
<g:google_product_category>Animals > Pet Supplies</g:google_product_category>
<g:custom_label_0>Made in Waterford, IE</g:custom_label_0>
</item>
</channel>
</rss>
解析方式为:
Product product = new Product();
try {
SyndFeedInput input = new SyndFeedInput();
SyndFeed feed = input.build(new XmlReader(file));
Namespace ns = Namespace.getNamespace("g", "http://base.google.com/ns/1.0");
for (SyndEntry entry : feed.getEntries()) {
for (Element element : entry.getForeignMarkup()) {
product.setId(element.getAttribute("id", ns).getValue()); // **id
}
}
System.out.println(product.getId());
} catch (Exception e) {
ex.printStackTrace();
}
带有 // **id
注释的部分 returns 一个 NullPointerException。
这是怎么回事?如何让它工作?
成功了! Namespace
部分不需要,for 是这样的:
for (SyndEntry entry : feed.getEntries()) {
for (Element element : entry.getForeignMarkup()) {
if (element.getQualifiedName().equalsIgnoreCase("g:id")) {
product.setId(element.getValue());
}
}
}
我正在尝试用 rometools
解析 RSS XML 文件,但我无法让它工作。下面的 Product
class 包含来自以下 RSS XML 文件的所有元素。但我似乎无法将文件正确映射到实体。
RSS XML 文件:
<?xml version="1.0"?>
<rss xmlns:g="http://base.google.com/ns/1.0" version="2.0">
<channel>
<title>Test Store</title>
<link>http://www.example.com</link>
<description>An example item from the feed</description>
<item>
<g:id>DB_1</g:id>
<g:title>Dog Bowl In Blue</g:title>
<g:description>Solid plastic Dog Bowl in marine blue color</g:description>
<g:link>http://www.example.com/bowls/db-1.html</g:link>
<g:image_link>http://images.example.com/DB_1.png</g:image_link>
<g:brand>Example</g:brand>
<g:condition>new</g:condition>
<g:availability>in stock</g:availability>
<g:price>9.99 GBP</g:price>
<g:shipping>
<g:country>UK</g:country>
<g:service>Standard</g:service>
<g:price>4.95 GBP</g:price>
</g:shipping>
<g:google_product_category>Animals > Pet Supplies</g:google_product_category>
<g:custom_label_0>Made in Waterford, IE</g:custom_label_0>
</item>
</channel>
</rss>
解析方式为:
Product product = new Product();
try {
SyndFeedInput input = new SyndFeedInput();
SyndFeed feed = input.build(new XmlReader(file));
Namespace ns = Namespace.getNamespace("g", "http://base.google.com/ns/1.0");
for (SyndEntry entry : feed.getEntries()) {
for (Element element : entry.getForeignMarkup()) {
product.setId(element.getAttribute("id", ns).getValue()); // **id
}
}
System.out.println(product.getId());
} catch (Exception e) {
ex.printStackTrace();
}
带有 // **id
注释的部分 returns 一个 NullPointerException。
这是怎么回事?如何让它工作?
成功了! Namespace
部分不需要,for 是这样的:
for (SyndEntry entry : feed.getEntries()) {
for (Element element : entry.getForeignMarkup()) {
if (element.getQualifiedName().equalsIgnoreCase("g:id")) {
product.setId(element.getValue());
}
}
}