[英]REGEX match two patterns between specific characters
我知道标题可能有点模糊,但我不知道如何制定它。 我有一个字符串,其中包含如下所示的文本:
$data["key1"] = "value1";
$data["key2"] = "value2";
$data["key3"] = "value3";
$data["key4"] = "value4";
我想匹配$data["
和]"
之后的所有内容以及= "
和";
在同一场比赛中,因此例如结果将是
Match 1 = {key1, value1}
Match 2 = {key2, value2}
Match 3 = {key3, value3}
Match 4 = {key4, value4}
到目前为止,我已经能够将这些值与
/(?<=]\s=\s\")(.*?)(?=\s*\"\;)/
但我也需要结果的第一部分,我不知道该怎么做。
另外,如果字符之间有(或没有)空格,有没有办法让它匹配?
例如
$data["key1"]= "value1";
$data["key2"]="value2";
$data["key3"] ="value3";
$data["key4"] ="value4" ;
也都匹配相同的东西吗?
尝试使用preg_match_all
:
$input = '$data["key1"] = "value1";';
preg_match_all('/\$\w+\["(.*?)"\]\s*=\s*"(.*?)";/', $input, $matches);
echo "Match = {" . $matches[1][0] . ", " . $matches[2][0] . "}";
这打印:
Match = {key1, value1}
您可以为每一行尝试以下操作。 基本上你只需要在每一行中搜索每对引号就可以了。
// $output_array is an array which the first index is your key and second is the value
// for example, array( "key1", "value1")
$input_lines = '$data["key1"] = "value1"';
preg_match_all('/\"\w+\"/', $input_lines, $output_array);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.