I am trying to scrape an xml file with the below format
file_sample.xml:
<rss version="2.0">
<channel>
<item>
<title>SENIOR BUDGET ANALYST (new)</title>
<link>https://hr.example.org/psp/hrapp&SeqId=1</link>
<pubDate>Wed, 18 Jul 2012 04:00:00 GMT</pubDate>
<category>All Open Jobs</category>
</item>
<item>
<title>BUDGET ANALYST (healthcare)</title>
<link>https://hr.example.org/psp/hrapp&SeqId=2</link>
<pubDate>Wed, 18 Jul 2012 04:00:00 GMT</pubDate>
<category>All category</category>
</item>
</channel>
</rss>
Below is my spider.py code
class TestSpider(XMLFeedSpider):
name = "testproject"
allowed_domains = {"www.example.com"}
start_urls = [
"https://www.example.com/hrapp/rss/careers_jo_rss.xml"
]
iterator = 'iternodes'
itertag = 'channel'
def parse_node(self, response, node):
title = node.select('item/title/text()').extract()
link = node.select('item/link/text()').extract()
pubdate = node.select('item/pubDate/text()').extract()
category = node.select('item/category/text()').extract()
item = TestprojectItem()
item['title'] = title
item['link'] = link
item['pubdate'] = pubdate
item['category'] = category
return item
Result:
2012-07-25 13:24:14+0530 [testproject] DEBUG: Scraped from <200 https://hr.templehealth.org/hrapp/rss/careers_jo_rss.xml>
{'title': [u'SENIOR BUDGET ANALYST (hospital/healthcare)',
u'BUDGET ANALYST'],
'link': [u'https://hr.example.org/psp/hrapp&SeqId=1',
u'https://hr.example.org/psp/hrapp&SeqId=2']
'pubdate': [u'Wed, 18 Jul 2012 04:00:00 GMT',
u'Wed, 18 Jul 2012 04:00:00 GMT']
'category': [u'All Open Jobs',
u'All category']
}
here as u can observe from the above result, all the results from the corresponding tags are combined in to single list, but i want to map according to their individual item tag like below as we do it for html scraping.
{'title': u'SENIOR BUDGET ANALYST (hospital/healthcare)'
'link': u'https://hr.example.org/psp/hrapp&SeqId=1'
'pubdate': u'Wed, 18 Jul 2012 04:00:00 GMT'
'category': u'All Open Jobs'
}
{'title': u'BUDGET ANALYST'
'link': u'https://hr.example.org/psp/hrapp&SeqId=2'
'pubdate': u'Wed, 18 Jul 2012 04:00:00 GMT'
'category': u'All category'
}
How can we scrape xml tag data according to separate main tag like item tag above.
Thanks in advance.............
Try changing your itertag from
itertag = 'channel'
to'itertag = 'item'
I recommend the use of feedparser:
results in
Just change itertag = 'item'.
If you refer to the documentation of parse_node method, it states that the method is called for the nodes matching the provided tag name (itertag). In you case it is 'item'(child node to 'channel' rootnode).