通过cURL抓一张带数据表的页面,只要得到TR下所有的单元格,用下面这种方法
$content = 内容; preg_match_all('/(.*?)<\/td>/',$content,$res); 但是有两种情况无法匹配
内容 和
未付 不知道为什么多了很多空格的单元格和带class的单元格无法匹配出来?由于不会正则,求一个pattern能够完全匹配出TD。
还有一个问题,页面上有两个table.一个用于各种条件筛选数据,一个盛放数据,如何只匹配盛放数据的那个table呢?2 个回答
$pattern = "/<td.*?>([\s\S]*?)<\/td>/";我也不太会,应该可以
2022-11-15 12:21 回答mobiledu2502872733
.在单行模式下无法匹配换行。
你可以用\s 匹配任意的空白符 \S 匹配任意不是空白符的字符举一反三啊,匹配带class的td
/<td[\s\S]*?>([\s\S]+?)<\/td>/匹配其中某个table的,同样举一反三啊,先从所有内容中匹配出table到一个数组中.
/<table[\s\S]*?>([\s\S]+?)<\/table>/然后看你要第几个,再用上面的正则匹配次不就好了。
还是那句话,举一反三啊!
2022-11-15 12:21 回答不能深加工
撰写答案今天,你开发时遇到什么问题呢?立即提问PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有