|
本文介绍下,用php实现获取标签之间文本的几个例子,有需要的朋友参考下。
以下例子提供了一种在标签之间检索文本的方法。 注意:不要使用正则表达式解析html。 通过使用正则表达式preg_match()、preg_match_all()函数,这二个函数进行的工作类似于php循环一样,多次遍历得到想要的结果。 另外,使用dom函数可以加快解析速度,得到干净的解析结果。 下面这个例子,使用 preg_match()函数来实现。 代码:
<?php /**
*
* @get text between tags
*
* @param string (The string with tags)
*
* @param string $tagname (the name of the tag
*
* @return string (Text between tags)
*
*/
function getTextBetweenTags($string, $tagname)
{
$pattern = "/<$tagname>(.*?)/";
preg_match($pattern, $string, $matches);
return $matches[1];
}
?>
注意:以上实现了一个简单的标签获取函数,不过它无法处理嵌套的标签,以及不完整的标签。 通过使用php的dom扩展,可以轻松解决这个问题。 来看下面的例子,函数本身有三个参考: $tag 标签之间的文本 $html 要搜索的HTML或XML $strict 告诉函数加载HTML或XML模式,默认为HTML模式。 第三个参数,允许设置函数来解析XML和一些XHTML文档中发现的自定义标签。 代码:
<?php /**
*
* @get text between tags
*
* @param string $tag The tag name
*
* @param string $html The XML or XHTML string
*
* @param int $strict Whether to use strict mode
*
* @return array
*
*/
function getTextBetweenTags($tag, $html, $strict=0)
{
/*** a new dom object ***/
$dom = new domDocument;
/*** load the html into the object ***/
if($strict==1)
{
$dom->loadXML($html);
}
else
{
$dom->loadHTML($html);
}
/*** discard white space ***/
$dom->preserveWhiteSpace = false;
/*** the tag by its tag name ***/
$content = $dom->getElementsByTagname($tag);
/*** the array to return ***/
$out = array();
foreach ($content as $item)
{
/*** add node value to the out array ***/
$out[] = $item->nodeValue;
}
/*** return the results ***/
return $out;
}
?>
在这个例子中,如果使用普通的html,则无需提供第三个参数。 这允许处理无效的、不完整的html标签。缺少关闭的 标签,然而,使用dom和loadHtml可以允许这样的偏差。 这个例子仍然会解析html,并检索一个数组中所有文字之间的所有锚标签。 代码:
<?php $html = '<body>
<h1>Heading</h1>
jbxue.com
<p>paragraph here</p><div class="aritcle_card flexRow">
<div class="artcardd flexRow">
<a class="aritcle_card_img" href="/xiazai/code/9265" title="DirCMS内容管理系统6.0"><img
src="https://img.php.cn/upload/webcode/000/000/015/175850640594515.jpg" alt="DirCMS内容管理系统6.0" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
<div class="aritcle_card_info flexColumn">
<a href="/xiazai/code/9265" title="DirCMS内容管理系统6.0">DirCMS内容管理系统6.0</a>
<p>DirCMS内容管理系统,是国内自主研发的一款功能强大而又不失小巧简洁的由PHP+Mysql架构的内容管理系统。DirCMS代码全部开源,便于使用者二次开发或定制;并采用简洁的模板标签技术,使制作模板更加容易,一般情况下,用DirCMS架构一个企业站只需半天时间即可,真正实现功能的简洁,实用,强大,灵活。可广泛应用于架构各类门户站,下载站,企业站,工作室等站点。</p>
</div>
<a href="/xiazai/code/9265" title="DirCMS内容管理系统6.0" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
</div>
</div><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/7fc7563c4182" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">PHP免费学习笔记(深入)</a>”;</p>
<p>Paragraph with a LINK TO jbxue.com</p>
<p>This is a broken paragraph
';
$content = getTextBetweenTags('a', $html);
foreach( $content as $item )
{
echo $item.'<br>';
}
?>
</p>
在最后的这个例子中,使用两个自定义标签,应用于XML或XHTML文件。 第三个参数被设置为使用XML模式和解析的自定义标签。 代码:
<?php $xhtml = '<html>
<body>
<para>This is a paragraph</para>
<para>This is another paragraph</para>
</body>
';
$content2 = getTextBetweenTags('para', $xhtml, 1);
foreach( $content2 as $item )
{
echo $item.'<br>';
}
?>
|
0
0
相关文章
DW如何插入PHP标签_快速插入代码片段的方法【操作】
WordPress中按分类名称获取所有文章的完整教程
PHP 中从多维数组动态生成 HTML 下拉选择框(select)的完整教程
Shopware插件中正确向HTML head添加多个meta标签的完整指南
实现鼠标悬停时自动加载并显示关联数据的完整教程
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。
463
2026.02.13
本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。
135
2026.02.13
本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。
64
2026.02.13
本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。
20
2026.02.13
本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。
26
2026.02.13
本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。
14
2026.02.12
本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。
524
2026.02.12
本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。
53
2026.02.12
热门下载
精品课程
最新文章


