douchuanhan8384 2019-04-09 14:41
浏览 6
已采纳

删除字符串中的所有单词“#User#,<br> <br>谢谢#在'#User#'和”#“之间提供”并从字符串中提取“#User#”

I need some regex that removes words as specified in title. I have tried below regex but it didn't worked. Also i want to extract "#User#" from given string - means starting with '#' and ending with '#' from string which don't contains any space.

preg_match_all("~#(.*?)#~", “#User#,<br><br>Thanks#For providing” , 
$wordReplaceArr_tmp);

Result of above code is below:

Output: User#,<br><br>Thanks

Expected result: "#User#"
  • 写回答

1条回答 默认 最新

  • dpa31905 2019-04-09 14:59
    关注

    If I got you right, you want the name(?) of the user between the first two hashtags and remove everything else. Your regex is greedy, means it captures more than it should. Add the hashtag to the "do not match" list and it will only capture anything UNTIL it finds another hashtag.

    $str = '#User#,<br><br>Thanks#For providing';
    preg_match_all('/#([^#]+)#/mis', $str, $matches);
    
    print_r($matches);
    

    The result of this code is the following:

    Array
    (
        [0] => Array
            (
                [0] => #User#
            )
    
        [1] => Array
            (
                [0] => User
            )
    
    )
    

    You can access the user now with $matches[1][0]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源