0

0

使用 lxml 解析 XML 时提取文本内容

DDD

DDD

发布时间:2025-10-08 12:37:01

|

410人浏览过

|

来源于php中文网

原创

使用 lxml 解析 xml 时提取文本内容

本文档旨在帮助开发者在使用 lxml 库解析 XML 文件时,正确提取包含子元素的父节点的文本内容。我们将通过示例代码和详细解释,展示如何利用 tail 属性以及迭代方法,从复杂的 XML 结构中获取目标文本。

在使用 lxml 解析 XML 时,直接访问元素的 text 属性可能无法获取到期望的全部文本内容,尤其当元素包含子元素时。text 属性仅返回起始标签到第一个子元素之间的文本。为了提取包含子元素的父节点的完整文本,需要结合使用 tail 属性和迭代方法。

理解 text 和 tail 属性

在 lxml 中,每个元素节点都有 text 和 tail 属性。

  • text: 表示元素的起始标签到第一个子元素(如果有)或结束标签之间的文本内容。
  • tail: 表示元素的结束标签到下一个兄弟元素的起始标签(如果有)或父元素的结束标签之间的文本内容。

以下面的 XML 片段为例:


    <indexmarker marker="AAA"/>
    <indexmarker marker="BBB"/>
    <indexmarker marker="CCC"/>Text Here

对于

元素,title.text 将返回 None (或者空字符串,取决于解析器配置),因为在 <title> 的起始标签和第一个子元素 <indexmarker> 之间没有直接的文本。而 "Text Here" 实际上是最后一个 <indexmarker> 元素的 tail 属性。<h3>提取文本的常用方法</h3> <ol> <li> <p><strong>利用 tail 属性:</strong></p> <p>如果已知目标文本是某个子元素的 tail 属性,可以直接访问该属性。例如,要提取上述 XML 片段中 "Text Here",可以先找到 <indexmarker> 元素,然后访问其 tail 属性。</indexmarker></p><div class="aritcle_card flexRow"> <div class="artcardd flexRow"> <a class="aritcle_card_img" href="/ai/1453" title="Cutout.Pro"><img src="https://img.php.cn/upload/ai_manual/001/431/639/68b6cc9153f6b201.png" alt="Cutout.Pro"></a> <div class="aritcle_card_info flexColumn"> <a href="/ai/1453" title="Cutout.Pro">Cutout.Pro</a> <p>AI驱动的视觉设计平台</p> </div> <a href="/ai/1453" title="Cutout.Pro" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a> </div> </div><pre class="brush:php;toolbar:false;">from lxml import etree xml_content = """ <root> <title> <indexmarker marker="AAA"/> <indexmarker marker="BBB"/> <indexmarker marker="CCC"/>Text Here """ root = etree.fromstring(xml_content) indexmarker_text = root.findall(".//indexmarker")[-1].tail # 找到最后一个 indexmarker 的 tail print(indexmarker_text)

这段代码首先解析 XML 内容,然后使用 findall 方法找到所有 元素,并获取最后一个元素的 tail 属性,即 "Text Here"。

  • 使用迭代器:

    如果需要提取元素及其所有子元素的文本内容,可以使用迭代器遍历元素的所有子节点,并将它们的 text 和 tail 属性连接起来。

    from lxml import etree
    
    xml_content = """
    
        title regular text 0
        title tail text 1
            <indexmarker marker="AAA"/>
            <indexmarker marker="BBB"/>
            <indexmarker marker="CCC"/>indexmarker tail text
        
        title regular text 2
    
    """
    
    root = etree.fromstring(xml_content)
    title_list = root.findall(".//title")
    
    for elem in title_list:
        text = (elem.text or "") + "".join(e.tail or "" for e in elem.findall("*"))
        print(text)

    这段代码首先找到所有的

    元素,然后对于每个 <title> 元素,将该元素的 text 属性和所有子元素的 tail 属性连接起来,从而得到完整的文本内容。
  • 注意事项

    • text 和 tail 属性可能为 None,因此在使用它们之前,需要进行判空处理,避免出现 AttributeError。
    • 在处理大型 XML 文件时,使用迭代器可以有效地减少内存占用
    • 根据 XML 文件的具体结构,可能需要调整代码以适应不同的情况。

    总结

    通过理解 text 和 tail 属性,并结合使用迭代器,可以灵活地提取 XML 文件中各种形式的文本内容。在实际应用中,需要根据 XML 文件的结构选择合适的方法,并注意处理可能出现的 None 值,以确保代码的健壮性。

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pdf怎么转换成xml格式
    pdf怎么转换成xml格式

    将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    1903

    2024.04.01

    xml怎么变成word
    xml怎么变成word

    步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

    2092

    2024.08.01

    xml是什么格式的文件
    xml是什么格式的文件

    xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

    1080

    2024.11.28

    js 字符串转数组
    js 字符串转数组

    js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    320

    2023.08.03

    js截取字符串的方法
    js截取字符串的方法

    js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

    212

    2023.09.04

    java基础知识汇总
    java基础知识汇总

    java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

    1502

    2023.10.24

    字符串介绍
    字符串介绍

    字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

    624

    2023.11.24

    java读取文件转成字符串的方法
    java读取文件转成字符串的方法

    Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

    653

    2024.03.22

    C++ 设计模式与软件架构
    C++ 设计模式与软件架构

    本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

    14

    2026.01.30

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    10分钟--Midjourney创作自己的漫画
    10分钟--Midjourney创作自己的漫画

    共1课时 | 0.1万人学习

    Midjourney 关键词系列整合
    Midjourney 关键词系列整合

    共13课时 | 0.9万人学习

    AI绘画教程
    AI绘画教程

    共2课时 | 0.2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

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