庆云php

庆云php

php解析html类库simple_html_dom,如何查询threeTextAction() 比较属性 tag,outertext,innertext,plaintext 的区别。

PHP 0

2023年11月20日 每日一猜答案: 答案:ABC
每日一猜答案分析:

php解析html类库simple_html_dom(2) 工具类官方文档:https://simplehtmldom.sourceforge.io/manual.htm 工具类下载地址:https://github.com/samacs/simple_html_dom python实现:python pyquery 解析html数据(2) 1、getAction() 获取HTML中的基本信息。 结果截图: 2、threeTextAction() 比较属性 tag,outertext,innertext,plaintext 的区别。 结果截图: 3、代码:
  1. /**
  2. * @todo simple_html_dom工具类基本数据获取
  3. * @author yfjs
  4. * @date 2018/4/24
  5. */
  6. class TestController extends Rest{
  7. /**
  8. * @todo 处理类
  9. * @author yfjs
  10. * @date 2019/4/24
  11. * find(selector, N) 查找满足条件的第N条数据
  12. */
  13. public function getAction(){
  14. require_once APP_PATH."/library/simple_html_dom.php"; //引入simple_html_dom类型文件
  15. $htmlObj = new simple_html_dom(); //工具类对象初始化
  16. //加载方式有一下三种
  17. /* $htmlObj->load_file('http://www.***.com'); // 从url中加载
  18. $htmlObj->load('HTML字符串'); // 从字符串中加载
  19. $htmlObj->load_file('/file/test.html'); //从文件中加载 */
  20. //为了演示我使用第二种
  21. $html = $this->getHtml(); //模拟HTML数据
  22. $htmlObj->load($html);
  23. //定位到这一行
    ;find方法返回的是一个二维对象数组,
  24. //在已知结果只有1条的情况下,我们可以把第二个参数设为0,即二维数组里的第一条数据。
  25. $articleObj = $htmlObj->find('body div.whole', 0);
  26. //标题只有一个,我们定位到元素,获取索引为0的即可。
  27. //这里echo $title;不写0的话会提示:Trying to get property of non-object in
  28. $title = $articleObj->find('div.head h2', 0)->plaintext;
  29. //作者、时间 属于同级目录, find(select, idx)方法的idx在这就体现出来了
  30. $author = $articleObj->find('div.head div span', 0)->plaintext; //索引为0,同级div标签下的第1个span
  31. $time = $articleObj->find('div.head div span', 1)->plaintext; //索引为1,同级div标签下的第2个span
  32. //a链接,图片 我们要获取的是标签上的属性,直接 (->属性名)即可;内容是div标签,可以循环得到文字
  33. $contentObj = $articleObj->find('div.content', 0); //0还是得加上。
  34. //获取 [body div.whole div.content a] a标签的href属性
  35. $aHref = $contentObj->find('a', 0)->href;
  36. //获取 [body div.whole div.content a img] img标签的src属性
  37. $imgSrc = $contentObj->find('a img', 0)->src;
  38. //循环获取P标签的内容,这里就是把find到的二维对象数组循环
  39. $pContent = '';
  40. foreach ( $contentObj->find('div.info') as $val ){
  41. $pContent .= trim($val->plaintext); //trim去除特殊字符
  42. }
  43. $htmlObj->clear(); //清空内存
  44. echo '文章标题 - ' . $title . PHP_EOL.
  45. '文章作者 - ' . $author . PHP_EOL.
  46. '文章时间 - ' . $time . PHP_EOL.
  47. '链接地址 - ' . $aHref . PHP_EOL.
  48. '图片地址 - ' . $imgSrc . PHP_EOL.
  49. '文字内容 - ' . $pContent;
  50. die();
  51. /* 打印内容 */
  52. /*
  53. 文章标题 - 美好的一天
  54. 文章作者 - 御风剑士
  55. 文章时间 - 2019-04-24
  56. 链接地址 - http://www.***.com
  57. 图片地址 - http://images.***.com
  58. 文字内容 - 回来的时候换了一条路。那里进过广场的公园。一如既往的有好多手机贴膜的小贩还有只有一个板凳面前一张
  59. 纸卖电话卡的小贩。我看见石榴花开了,红的黄的真的特别的好看。月季依然开得很娇艳。因为昨夜下雨的原因吗,
  60. 感觉空气好新鲜,身心愉悦脚步也很轻快。尽管没有太阳,但是我知道,今天又是美好的一天,也是生命中最年轻的一天。
  61. */
  62. }
  63. /**
  64. * @todo 这四个属性的区别
  65. * tag标签获取
  66. * outertext 外文本:节点的HTML + 节点内的所有内容(包含HTML标签)
  67. * innertext 内文本:节点内的所有内容(包含HTML标签)
  68. * plaintext 纯文本:节点内的所有内容(不包含HTML标签)
  69. */
  70. function threeTextAction(){
  71. require_once APP_PATH."/library/simple_html_dom.php"; //引入simple_html_dom类型文件
  72. $htmlObj = new simple_html_dom(); //工具类对象初始化
  73. $html = $this->getHtml(); //模拟HTML数据
  74. $htmlObj->load($html);
  75. $contentObj = $htmlObj->find('body div.whole div.content', 0);
  76. $tag = $contentObj->tag;
  77. $outertext = $contentObj->outertext;
  78. $innertext = $contentObj->innertext;
  79. $plaintext = $contentObj->plaintext;
  80. $htmlObj->clear(); //清空内存
  81. echo '标签 - ' . $tag .PHP_EOL . PHP_EOL.
  82. '外文本 - ' . $outertext .PHP_EOL . PHP_EOL.
  83. '内文本 - ' . $innertext .PHP_EOL . PHP_EOL.
  84. '纯文本 - ' . $plaintext .PHP_EOL;
  85. die();
  86. /* 打印内容 */
  87. /*
  88. 标签 - div
  89. 外文本 -
  90. 回来的时候换了一条路。那里进过广场的公园。一如既往的有好多手机贴膜的小贩还有只有一个板凳面前一张纸卖电话卡的小贩。
  • 我看见石榴花开了,红的黄的真的特别的好看。月季依然开得很娇艳。
  • 因为昨夜下雨的原因吗,感觉空气好新鲜,身心愉悦脚步也很轻快。尽管没有太阳,但是我知道,今天又是美好的一天,也是生命中最年轻的一天。
  • 内文本 -
  • 回来的时候换了一条路。那里进过广场的公园。一如既往的有好多手机贴膜的小贩还有只有一个板凳面前一张纸卖电话卡的小贩。
  • 我看见石榴花开了,红的黄的真的特别的好看。月季依然开得很娇艳。
  • 因为昨夜下雨的原因吗,感觉空气好新鲜,身心愉悦脚步也很轻快。尽管没有太阳,但是我知道,今天又是美好的一天,也是生命中最年轻的一天。
  • 纯文本 -
  • 回来的时候换了一条路。那里进过广场的公园。一如既往的有好多手机贴膜的小贩还有只有一个板凳面前一张纸卖电话卡的小贩。
  • 我看见石榴花开了,红的黄的真的特别的好看。月季依然开得很娇艳。
  • 因为昨夜下雨的原因吗,感觉空气好新鲜,身心愉悦脚步也很轻快。尽管没有太阳,但是我知道,今天又是美好的一天,也是生命中最年轻的一天。
  • */
  • }
  • /**
  • * @todo 获取HTML数据
  • * @return string 返回HTML字符串
  • */
  • function getHtml(){
  • $html = '
  • 大家好
  • 美好的一天

  • 御风剑士
  • 2019-04-24
  • 回来的时候换了一条路。那里进过广场的公园。一如既往的有好多手机贴膜的小贩还有只有一个板凳面前一张纸卖电话卡的小贩。
  • 我看见石榴花开了,红的黄的真的特别的好看。月季依然开得很娇艳。
  • 因为昨夜下雨的原因吗,感觉空气好新鲜,身心愉悦脚步也很轻快。尽管没有太阳,但是我知道,今天又是美好的一天,也是生命中最年轻的一天。
  • ';
  • return $html;
  • }
  • }
  •  
    分享到:

    上一篇遇到在命令行下提示'mysql' 不是内部或外部命令时怎么办

    下一篇Chanzhaoyu/chatgpt-web 的简单安装docker和docker-compose