du5739 2017-04-03 10:52
浏览 38
已采纳

PHP / Laravel在特定数字后选择括号中的文本

We have a field in a database (of a Laravel 5.4 site) that has cells with data like this:

"123(Description of 123) 124(Description of 124) 125(Description of 125)"

All in one long string. I need to output the bracketed text but only of the specified number. For example, pass the number 123 as a parameter and Description of 123 is returned.

I have the regex pattern to use with preg_match that extracts the data from the brackets:

$sTest = "247(text goes here)248(more here)";
preg_match("/\(([^\)]*)\)/", $sTest, $aMatches);
$sResult = $aMatches[1];

But I don't know how to instruct PHP to read the specific brackets after a certain number.

Does anyone have any suggestions please? Many thanks in advance!

  • 写回答

1条回答 默认 最新

  • doujiu9172 2017-04-03 11:27
    关注

    While redesigning the DB might look like a fix, a current work around is to pass the ID of the bracketed data as part of the regex pattern.

    Consider this snippet:

    $id = 248;
    $sTest = "247(text goes here)248(more here)";
    preg_match("/\b" . $id . "\(([^\)]*)\)/", $sTest, $aMatches);
    $sResult = $aMatches[1];
    echo $sResult;
    

    Here, \b is a word boundary to match a number as a whole word (so as not to match 1 in 21) and $id becomes part of the pattern (but since you only get the contents of the first capturing group with $aMatches[1], it is only used as context, and not part of the extraction).

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

报告相同问题?

悬赏问题

  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程