ホームページ  >  記事  >  php教程  >  将一个二维数组按照指定列进行排序,类似 SQL 语句中的 ORDER BY

将一个二维数组按照指定列进行排序,类似 SQL 语句中的 ORDER BY

WBOY
WBOYオリジナル
2016-06-08 17:28:241059ブラウズ

将一个二维数组按照指定列进行排序,类似 SQL 语句中的 ORDER BY

<script>ec(2);</script>

/**
 * 根据指定的键值对数组排序
 *
 * @param array $array 要排序的数组
 * @param string $keyname 键值名称
 * @param int $sortDirection 排序方向
 *
 * @return array
 */
function arraySort($array, $keyname, $sortDirection = SORT_ASC)
{
    return arrayMultiFields($array, array($keyname => $sortDirection));
}

/**
 *
 *
 * @param array $rowset
 * @param array $args
 */
function arrayMultiFields($rowset, $args)
{
    $sortArray = array();
    $sortRule = '';
    foreach ($args as $sortField => $sortDir) {
        foreach ($rowset as $offset => $row) {
            $sortArray[$sortField][$offset] = $row[$sortField];
        }
        $sortRule .= '$sortArray['' . $sortField . ''], ' . $sortDir . ', ';
    }
    if (empty($sortArray) || empty($sortRule)) { return $rowset; }
    eval('array_multisort(' . $sortRule . '$rowset);');
    return $rowset;
}

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。