예제 #1
0
 def test_regexp(self):
     html = '<div><h1 id="h1">foo</h1><h2>bar</h2></div>'
     sel = XpathSelector(fromstring(html))
     self.assertEqual('h2', sel.select('//*[re:test(text(), "b.r")]')\
                               .node().tag)
     self.assertEqual('foo', sel.select('//*[re:test(@id, "^h\d+$")]'
                                        '/text()').text())
예제 #2
0
 def test_regexp(self):
     html = '<div><h1 id="h1">foo</h1><h2>bar</h2></div>'
     sel = XpathSelector(fromstring(html))
     self.assertEqual('h2', sel.select('//*[re:test(text(), "b.r")]')\
                               .node().tag)
     self.assertEqual(
         'foo',
         sel.select('//*[re:test(@id, "^h\d+$")]'
                    '/text()').text())
예제 #3
0
 def test_select_node(self):
     sel = XpathSelector(self.tree)
     self.assertEquals("test", sel.select("//h1")[0]._node.text)
예제 #4
0
 def test_rex_method(self):
     sel = XpathSelector(self.tree)
     self.assertTrue(isinstance(sel.select("//li").rex("\w*"), RexResultList))
예제 #5
0
 def test_attr_does_not_exist(self):
     root = XpathSelector(self.tree)
     self.assertRaises(DataNotFound, lambda: root.select("//ul[1]").attr("id-xxx"))
예제 #6
0
 def test_attr(self):
     root = XpathSelector(self.tree)
     self.assertEqual("second-list", root.select("//ul[2]").attr("id"))
예제 #7
0
 def test_select_select(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(["one", "yet one"]), set([x.text() for x in root.select("//ul").select("./li[1]")]))
예제 #8
0
 def test_select_node(self):
     sel = XpathSelector(self.tree)
     self.assertEquals('test', sel.select('//h1')[0]._node.text)
예제 #9
0
 def test_select_node(self):
     sel = XpathSelector(self.tree)
     self.assertEquals('test', sel.select('//h1')[0]._node.text)
예제 #10
0
 def test_xpath_concat_function(self):
     html = '<a href="index.html"></a>'
     sel = XpathSelector(fromstring(html))
     self.assertEqual('/index.html', sel.select('concat("/",//a/@href)')\
                               .text())
예제 #11
0
 def test_attr_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(['li-1', 'li-2']),
                       set(root.select('//ul[@id="second-list"]/li')
                               .attr_list('class')))
예제 #12
0
 def test_attr_with_default_value(self):
     root = XpathSelector(self.tree)
     self.assertEqual('z', root.select('//ul[2]').attr('id-xxx',
                                                       default='z'))
예제 #13
0
 def test_attr(self):
     root = XpathSelector(self.tree)
     self.assertEqual('second-list', root.select('//ul[2]').attr('id'))
예제 #14
0
 def test_text_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(['one', 'yet one']),
                       set(root.select('//ul/li[1]').text_list()))
예제 #15
0
 def test_sel_list_number(self):
     sel = XpathSelector(self.tree)
     self.assertEquals(4, sel.select('//ul/li[last()]').number())
     self.assertEquals(6, sel.select('//ul/li[last()]/@id').number())
예제 #16
0
 def test_text_selector_select(self):
     sel = XpathSelector(self.tree).select('//li/text()').one()
     self.assertRaises(SelectionRuntimeError, lambda: sel.select('foo'))
예제 #17
0
 def test_select_select(self):
     root = XpathSelector(self.tree)
     self.assertEquals(
         set(['one', 'yet one']),
         set([x.text() for x in root.select('//ul').select('./li[1]')]))
예제 #18
0
 def test_xpath_concat_function(self):
     html = '<a href="index.html"></a>'
     sel = XpathSelector(fromstring(html))
     self.assertEqual('/index.html', sel.select('concat("/",//a/@href)')\
                               .text())
예제 #19
0
 def test_text_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(['one', 'yet one']),
                       set(root.select('//ul/li[1]').text_list()))
예제 #20
0
 def test_selector_number(self):
     sel = XpathSelector(self.tree)
     self.assertEquals(4, sel.select('//ul/li[last()]').one().number())
     self.assertEquals(6, sel.select('//ul/li[last()]/@id').one().number())
예제 #21
0
 def test_attr(self):
     root = XpathSelector(self.tree)
     self.assertEqual('second-list', root.select('//ul[2]').attr('id'))
예제 #22
0
 def test_text_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(["one", "yet one"]), set(root.select("//ul/li[1]").text_list()))
예제 #23
0
 def test_attr_with_default_value(self):
     root = XpathSelector(self.tree)
     self.assertEqual('z',
                      root.select('//ul[2]').attr('id-xxx', default='z'))
예제 #24
0
 def test_attr_with_default_value(self):
     root = XpathSelector(self.tree)
     self.assertEqual("z", root.select("//ul[2]").attr("id-xxx", default="z"))
예제 #25
0
 def test_attr_does_not_exist(self):
     root = XpathSelector(self.tree)
     self.assertRaises(DataNotFound,
                       lambda: root.select('//ul[1]').attr('id-xxx'))
예제 #26
0
 def test_attr_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(["li-1", "li-2"]), set(root.select('//ul[@id="second-list"]/li').attr_list("class")))
예제 #27
0
 def test_attr_list(self):
     root = XpathSelector(self.tree)
     self.assertEquals(
         set(['li-1', 'li-2']),
         set(root.select('//ul[@id="second-list"]/li').attr_list('class')))
예제 #28
0
 def test_text_selector_select(self):
     sel = XpathSelector(self.tree).select("//li/text()").one()
     self.assertRaises(SelectionRuntimeError, lambda: sel.select("foo"))
예제 #29
0
 def test_rex_method(self):
     sel = XpathSelector(self.tree)
     self.assertTrue(
         isinstance(sel.select('//li').rex('\w*'), RexResultList))
예제 #30
0
 def test_selector_number(self):
     sel = XpathSelector(self.tree)
     self.assertEquals(4, sel.select("//ul/li[last()]").one().number())
     self.assertEquals(6, sel.select("//ul/li[last()]/@id").one().number())
예제 #31
0
 def test_select_select(self):
     root = XpathSelector(self.tree)
     self.assertEquals(set(['one', 'yet one']),
                       set([x.text() for x in root.select('//ul')
                                                  .select('./li[1]')]))