[英]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.