我有具有相同表单字段名称的标签,在每个标签中我都希望显示类似
的数据$meta_query = array(
'relation' => 'OR',
array(
'key' => 'Demo',
'value' => 'demo',
'compare' => '=',
'type' => 'NUMERIC',
),
array(
'key' => 'test',
'value' => 'tes',
'compare' => '=',
'type' => 'NUMERIC',
),
);
但是我得到如下响应:
Array
(
[relation] => AND
[key1] => Demo
[value1] => demo
[compare1] => =
[type1] => NUMERIC
[key2] => test
[value2] => test
[compare2] => =
[type2] => NUMERIC
)
任何解决方案将不胜感激!
答案 0 :(得分:1)
结合使用array_splice和array_chunk即可达到目的。
$new = array_merge(array_splice($arr, 0,1), array_chunk($arr, 4, true));
var_export($new);
输出:
array (
'relation' => 'AND',
0 =>
array (
'key1' => 'Demo',
'value1' => 'demo',
'compare1' => '=',
'type1' => 'NUMERIC',
),
1 =>
array (
'key2' => 'test',
'value2' => 'test',
'compare2' => '=',
'type2' => 'NUMERIC',
),
)
如果需要删除键中的1和2,则可以循环数组并使用array_combine替换键
foreach($new as &$a){
if(is_array($a)) $a = array_combine(["key", "value", "compare", "type"],$a);
}
拼接数组,并使用preg_match分隔键中的单词和数字。
将值添加到结果数组中的“键号-1”。
$new = array_splice($arr, 0,1);
foreach($arr as $k => $v){
preg_match("/(.*?)(\d+)/", $k, $m);
$new[$m[2]-1][$m[1]] = $v;
}
var_export($new);
答案 1 :(得分:0)
以以下格式设置字段名称的索引:
<input type="text" name="entity[0]key"/>
<input type="text" name="entity[0]value"/>
<input type="text" name="entity[0]compare"/>
<input type="text" name="entity[0]type"/>
<input type="text" name="entity[1]key"/>
<input type="text" name="entity[1]value"/>
<input type="text" name="entity[1]compare"/>
<input type="text" name="entity[1]type"/>