0

我需要在 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 行。

有没有更简单的方法来重命名数组键而不移动它们?

4

1 回答 1

2

试试这个,应该更简单

foreach($array as $k=>$v){
   if($k=='Q test'){
      $new_arr['Q tes'] = $array['Q test'];
   }else{
      $new_arr[$k] = $v;
   }
}

print_r($new_arr); //set $array = $new_arr;  to overwrite all values
于 2012-12-03T10:46:59.700 回答