繁体   English   中英

使用一个表中的值作为另一个表中的键 (PHP)

[英]Use values from one table as keys in another (PHP)

我有一个数组,我想将其值用作散列中的键。 我有一个:

$x = ['a', 'b', 'c'];
$r = 'result;

或者

$obj=['name'=>'a/b/c', 'value'=>'result']

我想将其转换为:

$x['a']['b']['c'] = 'result';

如何拥抱它?

您可以使用递归函数来完成

function convert(array $keys, $value) {
  if(count($keys) === 0){
    return $value;       
  }
  $key = $keys[0];
  $rest = array_slice($keys, 1);
  return [$key => convert($rest, $value)];
}

在第一种情况下

$x = convert($x, $result);

第二种情况

$x = convert(explode('/', $obj['name']), $obj['value']);

我猜您想创建一个对象数组 a、b 和 c 并想用结果填充它,对吗?

你的数组: $x = ['a', 'b', 'c'];

让我先解释一下 $x。

如果你 var_dump 这个数组,你会得到:

PHP代码

$x = ['a', 'b', 'c'];
var_dump($x);

输出:

array(3) { [0]=> string(1) "a" [1]=> string(1) "b" [2]=> string(1) "c" }

但实际上你想创造这样的东西?

PHP代码

$r = 'result';
$x['a'] = $x['b'] = $x['c'] = $r;
var_dump($x);

输出:

array(3) { ["c"]=> string(6) "result" ["b"]=> string(6) "result" ["a"]=> string(6) "result" }
$x = ['a', 'b', 'c'];
$r = 'result';

$temp = [];

for ($i = count($x)-1; $i >= 0; $i--) {
  if ($i === count($x)-1) {
    $temp[$x[$i]] = $r;
  } else {
    $temp[$x[$i]] = $temp;
    unset($temp[$x[$i+1]]);
  }
}

print_r($temp);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM