我有一个形式key =>值的关联数组,其中key是一个数值,但它不是一个连续的数值。键实际上是一个ID号,值是一个计数。这对于大多数实例来说都很好,但是我想要一个函数获得人类可读的数组名称并将其用作键,而不更改值。
我没有看到这样做的函数,但我假设我需要提供旧键和新键(我都有)并转换数组。有没有一种有效的方法来做到这一点?
我有一个形式key =>值的关联数组,其中key是一个数值,但它不是一个连续的数值。键实际上是一个ID号,值是一个计数。这对于大多数实例来说都很好,但是我想要一个函数获得人类可读的数组名称并将其用作键,而不更改值。
我没有看到这样做的函数,但我假设我需要提供旧键和新键(我都有)并转换数组。有没有一种有效的方法来做到这一点?
当前回答
最好的方法是使用引用,而不是使用unset(这是清理内存的另一个步骤)
$tab = ['two' => [] ];
解决方案:
$tab['newname'] = & $tab['two'];
你有一份原件和一份有新名字的参考资料。
或者如果你不想在一个值中有两个名字是很好的,让另一个TAB和foreach引用
foreach($tab as $key=> & $value) {
if($key=='two') {
$newtab["newname"] = & $tab[$key];
} else {
$newtab[$key] = & $tab[$key];
}
}
迭代键比克隆所有数组更好,如果你有长数据,如100行+++等,清洗旧数组。
其他回答
您可以使用第二个关联数组将人类可读的名称映射到id。这也将提供多对1关系。然后这样做:
echo 'Widgets: '。美元$ data [humanreadbleMapping[“窗口小部件”]];
最好的方法是使用引用,而不是使用unset(这是清理内存的另一个步骤)
$tab = ['two' => [] ];
解决方案:
$tab['newname'] = & $tab['two'];
你有一份原件和一份有新名字的参考资料。
或者如果你不想在一个值中有两个名字是很好的,让另一个TAB和foreach引用
foreach($tab as $key=> & $value) {
if($key=='two') {
$newtab["newname"] = & $tab[$key];
} else {
$newtab[$key] = & $tab[$key];
}
}
迭代键比克隆所有数组更好,如果你有长数据,如100行+++等,清洗旧数组。
$arr[$newkey] = $arr[$oldkey];
unset($arr[$oldkey]);
简单的东西:
此函数将接受目标$哈希值,$replacement也是包含newkey=>oldkey关联的哈希值。
这个函数将保留原始顺序,但对于非常大的数组(比如超过10k的记录),在性能和内存方面可能会有问题。
function keyRename(array $hash, array $replacements) {
$new=array();
foreach($hash as $k=>$v)
{
if($ok=array_search($k,$replacements))
$k=$ok;
$new[$k]=$v;
}
return $new;
}
这个替代函数也会做同样的事情,具有更好的性能和内存使用,代价是失去原来的顺序(这应该不是问题,因为它是哈希表!)
function keyRename(array $hash, array $replacements) {
foreach($hash as $k=>$v)
if($ok=array_search($k,$replacements))
{
$hash[$ok]=$v;
unset($hash[$k]);
}
return $hash;
}
$array = [
'old1' => 1
'old2' => 2
];
$renameMap = [
'old1' => 'new1',
'old2' => 'new2'
];
$array = array_combine(array_map(function($el) use ($renameMap) {
return $renameMap[$el];
}, array_keys($array)), array_values($array));
/*
$array = [
'new1' => 1
'new2' => 2
];
*/