如何将二维数组转换为一维数组?

4
我想将我的二维数组转换为一维数组。 当我执行var_dump($image_name_db);时, 它显示:
array(2) {
  [0]=>
  array(1) {
    ["image"]=>
    string(7) "pic.PNG"
  }
  [1]=>
  array(1) {
    ["image"]=>
    string(14) "abouttown3.jpg"
  }
}

现在我该如何将其转换为1D数组。因为我想比较两个数组。一个数组是1D的,另一个数组是2D的,所以我想将2D数组变成1D数组。因此我需要将它们都变成1D数组,以便更容易地进行比较。 我正在使用CodeIgniter。


你能展示一下你为此所尝试的内容吗? - Saty
为什么不能比较二维数组。 - xNeyte
2
如果使用的是 PHP 版本 5.5.0,则可以使用 array_column($arr, 'image'); - Tamil Selvan C
@tamil-selvan,你应该发布一个答案,并包含对5.5之前用户实现的引用。 - Stephen
5个回答

2

如果 PHP 版本是 5.5+,可以使用 array_column() 函数。

array_column($image_name_db, 'image');

请看:

参见:http://php.net/manual/en/function.array-column.php

对于以下不支持的版本,请使用https://github.com/ramsey/array_column

if (!function_exists('array_column')) {
    /**
     * Returns the values from a single column of the input array, identified by
     * the $columnKey.
     *
     * Optionally, you may provide an $indexKey to index the values in the returned
     * array by the values from the $indexKey column in the input array.
     *
     * @param array $input A multi-dimensional array (record set) from which to pull
     *                     a column of values.
     * @param mixed $columnKey The column of values to return. This value may be the
     *                         integer key of the column you wish to retrieve, or it
     *                         may be the string key name for an associative array.
     * @param mixed $indexKey (Optional.) The column to use as the index/keys for
     *                        the returned array. This value may be the integer key
     *                        of the column, or it may be the string key name.
     * @return array
     */
    function array_column($input = null, $columnKey = null, $indexKey = null)
    {
        // Using func_get_args() in order to check for proper number of
        // parameters and trigger errors exactly as the built-in array_column()
        // does in PHP 5.5.
        $argc = func_num_args();
        $params = func_get_args();
        if ($argc < 2) {
            trigger_error("array_column() expects at least 2 parameters, {$argc} given", E_USER_WARNING);
            return null;
        }
        if (!is_array($params[0])) {
            trigger_error(
                'array_column() expects parameter 1 to be array, ' . gettype($params[0]) . ' given',
                E_USER_WARNING
            );
            return null;
        }
        if (!is_int($params[1])
            && !is_float($params[1])
            && !is_string($params[1])
            && $params[1] !== null
            && !(is_object($params[1]) && method_exists($params[1], '__toString'))
        ) {
            trigger_error('array_column(): The column key should be either a string or an integer', E_USER_WARNING);
            return false;
        }
        if (isset($params[2])
            && !is_int($params[2])
            && !is_float($params[2])
            && !is_string($params[2])
            && !(is_object($params[2]) && method_exists($params[2], '__toString'))
        ) {
            trigger_error('array_column(): The index key should be either a string or an integer', E_USER_WARNING);
            return false;
        }
        $paramsInput = $params[0];
        $paramsColumnKey = ($params[1] !== null) ? (string) $params[1] : null;
        $paramsIndexKey = null;
        if (isset($params[2])) {
            if (is_float($params[2]) || is_int($params[2])) {
                $paramsIndexKey = (int) $params[2];
            } else {
                $paramsIndexKey = (string) $params[2];
            }
        }
        $resultArray = array();
        foreach ($paramsInput as $row) {
            $key = $value = null;
            $keySet = $valueSet = false;
            if ($paramsIndexKey !== null && array_key_exists($paramsIndexKey, $row)) {
                $keySet = true;
                $key = (string) $row[$paramsIndexKey];
            }
            if ($paramsColumnKey === null) {
                $valueSet = true;
                $value = $row;
            } elseif (is_array($row) && array_key_exists($paramsColumnKey, $row)) {
                $valueSet = true;
                $value = $row[$paramsColumnKey];
            }
            if ($valueSet) {
                if ($keySet) {
                    $resultArray[$key] = $value;
                } else {
                    $resultArray[] = $value;
                }
            }
        }
        return $resultArray;
    }
}

或者使用array_map函数

$image_name_arr = array_map(function($arr){
   return $arr['image'];
},$image_name_db);

1
你需要遍历数组并将图像存储到一个一维数组中。
<?php
$arr = array();
$arr[0]['image'] = 'pic.PNG';
$arr[1]['image'] = 'abouttown3.jpg';
$images = array();
if (! empty($arr)) {
  foreach ($arr as $row) {
    $images[] = $row['image'];
  }
}

echo "<br/> Existing";
echo '<pre>';
print_r($arr);
echo '</pre>';

echo "<br/> New";
echo '<pre>';
print_r($images);
echo '</pre>';

工作演示:


1
尝试使用 -
$array = array(array("image" => "pic.PNG"),  array("image" => "abouttown3.jpg"));
$new = array_map(function($arr) {
    return $arr['image'];
}, $array);

OutPut

array(2) {
  [0]=>
  string(7) "pic.PNG"
  [1]=>
  string(14) "abouttown3.jpg"
}

我正在这样做: $images_db_name = call_user_func_array('array_merge',$images_db_name); 但是它没有显示任何东西。 - Bakht

1

最好的方法是使用array_map,根据php doc

array_map()将对每个元素应用回调函数后返回包含array1所有元素的数组。回调函数接受的参数数量应匹配传递给array_map()的数组数量。

示例:

$output = array_map(function($current){
   return $current['image'];
},$your_array);

说明:

回调函数接收迭代数组(2D 数组 $your_array)中的当前元素($current),并返回要推送到新数组(1D 数组 $output)的值。


请您能否详细阐述一下? - Bakht

0

一个数组是一维的,另一个数组是二维的,所以我想将二维数组转换为一维数组,以便更容易地进行比较。 - Bakht

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接