我需要在 CSV 文件中写入一个数组,其中列顺序不能更改。但我想将列标题减少到最大 64 个字符的长度。为了使问题更笼统,让我们举一个简单的例子:
$array = array(
'A te' => 'foo A',
'Q test' => 'foo Q',
'Z test' => 'foo Z',
);
var_dump($array);
给 :
array (size=3)
'A te' => string 'foo A' (length=5)
'Q test' => string 'foo Q' (length=5)
'Z test' => string 'foo Z' (length=5)
现在,我想将“Q test”键重命名为“Q tes”。如果我做 :
$swap = $array["Q test"];
unset($array["Q test"]);
$array["Q tes"] = $swap;
var_dump($array);
显示:
array (size=3)
'A te' => string 'foo A' (length=5)
'Z test' => string 'foo Z' (length=5)
'Q tes' => string 'foo Q' (length=5)
专栏的位置发生了变化,这不是我想要的。
我通过使用(在这里,将键减少到 5 个字符)解决了我的问题:
$keys = array_keys($array);
$values = array_values($array);
$count = count($keys);
for ($i = 0; ($i < $count); $i++)
{
if (mb_strlen($keys[$i]) > 5)
{
$keys[$i] = mb_substr($keys[$i], 0, 5);
}
}
$array = array_combine($keys, $values);
var_dump($array);
输出:
array (size=3)
'A te' => string 'foo A' (length=5)
'Q tes' => string 'foo Q' (length=5)
'Z tes' => string 'foo Z' (length=5)
但这看起来非常耗费资源......我确实需要在我的每一行上执行这样的代码,并且我有 10k 到 100k 行。
有没有更简单的方法来重命名数组键而不移动它们?