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).

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

报告相同问题?

悬赏问题

  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型
  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条