繁体   English   中英

如何从数组数组(多维数组)加入逗号分隔的字符串?

[英]How to join into a comma-separated string from array of arrays (multidimensional-array)?

好的,我知道要从PHP的字符串数组中获取逗号分隔的字符串,您可以执行

$stringA = array("cat","dog","mouse");
$commaSeperatedS = join(',', $stringA);

但是,如果我有一个数组数组(而不是简单的字符串数组)怎么办?

$myAssociativeA = 
      array(
           [0] => array("type"=>"cat", "sex"=>"male")
           , [1] => array("type"=>"dog", "sex"=>"male")
      );

我的目标是从每个数组的特定属性(例如“ type”)中获取一个逗号分隔的字符串? 我试过了

$myGoal = join(',', $myAssociativeA{'type'});

在这种情况下,我对$myGoal目标值为"cat,dog" 有没有一种简单的方法而不必手动遍历每个数组,提取属性然后在最后进行联接?

这应该为您工作:

(这里我只是用array_column()得到想要的列,然后用implode()其内array_column()

echo implode(",", array_column($myAssociativeA, "type"));

另一个选择是使用array_walk()返回所需的密钥:

array_walk($myAssociativeA, function(&$value, $key, $return) {
  $value = $value[$return];
}, 'type');

echo implode(', ', $myAssociativeA); // cat, dog

对于较旧的PHP版本有用-@ Rizier123使用array_column()的答案非常适合PHP 5.5.0+

如果您的PHP <5.5.0和> = 5.3.0(感谢@ Rizier123 )并且不能使用array_column()可以使用array_column()

<?php

$myAssociativeA = array(array("type"=>"cat", "sex"=>"male"), array("type"=>"dog", "sex"=>"male"));

$myGoal = implode(',', array_map(function($n) {return $n['type'];}, $myAssociativeA));

echo $myGoal;
?>

编辑: @scrowler的注释中的建议,现在的代码是:

<?php

$myAssociativeA = array(array("type"=>"cat", "sex"=>"male"), array("type"=>"dog", "sex"=>"male"));
$column = 'type';

$myGoal = implode(',', array_map(function($n) use ($column) {return $n[$column];}, $myAssociativeA));

echo $myGoal;
?>

输出:

猫狗

在以下网址中了解有关array_map更多信息: http : array_map

您只需要遍历数组并自己生成字符串。

<?php
   $prepend = '';
   $out = '';
   $myAssociativeA = array(
      array('type' => 'cat'),
      array('type' => 'dog')
   );

   foreach($myAssociativeA as $item) {
      $out .= $prepend.$item['type'];
      $prepend = ', ';
   }
   echo $out;
?>

您可以轻松地将其转换为函数。

<?php
   function implode_child($array,$key) {
     $prepend = '';
     $out = '';
     foreach($array as $item) {
        $out .= $prepend.$item[$key];
        $prepend = ', ';
     }
     return $out;
   }
?>

好的,假设您的assoc数组字段的排序方式始终与您可以像这样使用代码段相同。 但是,您仍然需要遍历数组。

$csvString = "";
foreach ( $myAssociativeA as $row ) {
    $csvRow = implode(",", $row);
    $csvString .= $csvRow . PHP_EOL;
}

现在,如果您不想将整个CSV存储在变量中(您不应该这样做),请查看http://www.w3schools.com/php/func_filesystem_fputcsv.asp并查看示例如何将其直接放入文件。

暂无
暂无

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

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