如何使用xpath获取最高页码?

How to get the highest page number using xpath?

我已经编写了一个 xpath 表达式来从某些 html elements 中获取 page number 的最大值。但是,在这种情况下,使用下面的 xpath 我得到的最后一个文本是 Next Page 。我希望我的 xpath 以这样的方式运行,以便我可以获得最高的数字,就像 6 使用它一样。

应该应用 xpath 的元素:

content = """
<div class="nav-links"><span aria-current="page" class="page-numbers current"><span class="meta-nav screen-reader-text">Page </span>1</span>
<a class="page-numbers" href="https://page/2/"><span class="meta-nav screen-reader-text">Page </span>2</a>
<span class="page-numbers dots">…</span>
<a class="page-numbers" href="https://page/6/"><span class="meta-nav screen-reader-text">Page </span>6</a>
<a class="next page-numbers" href="https://page/2/"><span class="screen-reader-text">Next Page</span></a></div>
"""

到目前为止我尝试过的:

from lxml.html import fromstring

root = fromstring(above_content)
pagenum = root.xpath("//*[contains(@class,'page-numbers')][last()]/span")[0].text
print(pagenum)

我的输出:

Next Page

我希望得到的输出:

6

您可以使用准确的 class 名称来避免获取下一个 link:

//a[@class="page-numbers"][last()]

请注意,contains(@class,'page-numbers') 将 return 您 link 使用数字和下一个,而 @class="page-numbers" 仅使用数字