$html = '<html><body><a href="https://www.example.com">Example</a></body></html>';
// 匹配所有的 a 标签
preg_match_all('/<a[^>]+href="([^"]*)"[^>]*>(.*)</a>/siU', $html, $matches);
// 输出匹配结果
print_r($matches[1]); // 输出所有链接的 URL
print_r($matches[2]); // 输出所有链接的文本内容
解释一下这个正则表达式:
<a: 匹配 a 标签的起始标记
[^>]+: 匹配 a 标签的属性,直到 > 符号为止
href="([^"]*)": 匹配 href 属性的值,使用 [^"]* 表示可以匹配任意数量的非双引号字符
[^>]*: 匹配 a 标签的其他属性,使用 * 表示可以匹配零个或多个非 > 字符
>(.*)</a>: 匹配 a 标签的结束标记和文本内容,使用 .* 表示可以匹配任意数量的字符,使用 U 修饰符表示非贪婪匹配,以避免匹配到多个 a 标签的文本内容
请注意,使用正则表达式来匹配 HTML 不是一个完美的解决方案,因为 HTML 可以有多种不同的格式,有时可能会遇到复杂的情况。更好的方法是使用专门的 HTML 解析器,如 PHP 的 DOM 解析器或 Simple HTML DOM 解析器,来处理 HTML 内容。