首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >PHP Regex:从<a>lucky <b>charm</b></a>中提取幸运和charm

PHP Regex:从<a>lucky <b>charm</b></a>中提取幸运和charm
EN

Stack Overflow用户
提问于 2013-02-26 06:58:53
回答 3查看 34关注 0票数 0

Reqex问题:提取单词

代码语言:javascript
运行
复制
lucky
charms

发件人字符串:

代码语言:javascript
运行
复制
<a>lucky <b>charms</b></a>

我的尝试是:

代码语言:javascript
运行
复制
preg_match_all("/<(.*)>(.*)<\/(.*)>+/is", $text, $matches);
print_r($matches);

结果:

代码语言:javascript
运行
复制
Array
(
    [0] => Array
        (
            [0] => <a>lucky <b>charms</b></a>
        )

    [1] => Array
        (
            [0] => a>lucky <b>charms</b
        )

    [2] => Array
        (
            [0] => 
        )

    [3] => Array
        (
            [0] => a
        )

)
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-02-26 07:07:41

结束标记和下一个开始标记之间的所有内容如何?

代码语言:javascript
运行
复制
preg_match_all("/\>([^\<]+)\</is", $text, $matches);

那么你想要的匹配项就是$matches[1]格式的

代码语言:javascript
运行
复制
Array
(
    [0] => Array
        (
            [0] => >lucky <
            [1] => >charms<
        )
    [1] => Array
        (
            [0] => lucky 
            [1] => charms
        )
)
票数 0
EN

Stack Overflow用户

发布于 2013-02-26 07:03:18

如果你总是有这样的结构,你可以使用:

代码语言:javascript
运行
复制
preg_match("#<(.*?)>(.*?)<(.*?)>(.*?)</\\3></\\1>#is", '<a>lucky <b>charms</b></a>', $matches);

$matches包含以下内容:

代码语言:javascript
运行
复制
array(5) {
  [0]=>
  string(26) "lucky charms"
  [1]=>
  string(1) "a"
  [2]=>
  string(6) "lucky "
  [3]=>
  string(1) "b"
  [4]=>
  string(6) "charms"
}
票数 0
EN

Stack Overflow用户

发布于 2013-02-26 07:03:34

你的正则表达式是不合适的,因为*是在使用gready吗?在下面这样的代码中设置* non-gready或更改正则表达式

代码语言:javascript
运行
复制
<([^>]+)>(.*?)</\1>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15078152

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档