python - lxml中xpath获取本节点及以下所有节点的text()方法?
ringa_lee
ringa_lee 2017-04-17 17:34:33
[Python讨论组]
<ul id="parameter2" class="p-parameter-list">
 <li title='养生堂天然维生素E软胶囊'>商品名称:养生堂天然维生素E软胶囊</li>
 <li title='720135'>商品编号:720135</li>
 <li title='养生堂'>品牌:<a>养生堂</a></li>
</ul>

以上是网页源码,现通过xpath匹配所有Li

import lxml.etree as etree
html = html.decode("utf-8")
tree = etree.HTML(html)
property_list_reg = "//ul[@id='parameter2']/li/text()"
property_lst = tree.xpath(property_list_reg)
print len(property_lst)   

输出结果:

3
商品名称:养生堂天然维生素E软胶囊
商品编号:720135
品牌:

如果换成:

property_list_reg = "//ul[@id='parameter2']/li//text()" #此处//

输出结果:

4
商品名称:养生堂天然维生素E软胶囊
商品编号:720135
品牌:
养生堂

显然,这不是我想要的结果,我想要的结果是这样

3
商品名称:养生堂天然维生素E软胶囊
商品编号:720135
品牌: 养生堂

求大神指导~ 该如何实现?

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
怪我咯

正确的做法时使用Xpath的 string 函数

import lxml.etree as etree
html = """
<ul id="parameter2" class="p-parameter-list">
 <li title='养生堂天然维生素E软胶囊'>商品名称:养生堂天然维生素E软胶囊</li>
 <li title='720135'>商品编号:720135</li>
 <li title='养生堂'>品牌:<a>养生堂</a></li>
</ul>
"""
tree = etree.HTML(html)
property_list_reg = '//ul[@id="parameter2"]//li'
property_lst = tree.xpath(property_list_reg)
for e in property_lst:
    print(e.xpath('string(.)'))
print(len(property_lst))
大家讲道理

在XPath的定义中, "//" 就是 "/descendant-or-self::node()/",表示当前节点或后代节点的匹配,所以你用"//text()"肯定是会匹配到下面的子节点的,比较清晰的办法是匹配到父节点li层,然后手动处理下子节点。

html = """
<ul id="parameter2" class="p-parameter-list">
 <li title='养生堂天然维生素E软胶囊'>商品名称:养生堂天然维生素E软胶囊</li>
 <li title='720135'>商品编号:720135</li>
 <li title='养生堂'>品牌:<a>养生堂</a></li>
</ul>
"""

html = html.decode("utf-8")
tree = etree.HTML(html)

property_list_reg = '//ul[@id="parameter2"]/li'


def tryFindChild(element):
    children = element.getchildren()
    if len(children):
        return element.text + " " + children[0].text
    else:
        return element.text


property_lst = tree.xpath(property_list_reg)
for e in property_lst:
    print tryFindChild(e)

print len(property_lst)

输出
商品名称:养生堂天然维生素E软胶囊
商品编号:720135
品牌: 养生堂
3

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号