`Laravel`版`小丑路人社区`改版中,与`Hyperf版小丑路人社区`数据互动,此版本改版中……尚未彻底完结!

Q:

(PHP)汉字首字母进行分组


/**
 * Class ChineseCharactersByInitialGrouping
 *
 * 汉字首字母进行分组
 *
 * @package App\Helper\ExtendClass
 */
class ChineseCharactersByInitialGrouping
{
    public function demo($demo_data, $key)
    {
        return $data = $this->groupByInitials($demo_data, $key);
    }

    /**
     * 二维数组根据首字母分组排序
     *
     * @param  array   $data       二维数组
     * @param  string  $targetKey  首字母的键名
     *
     * @return array    根据首字母关联的二维数组
     */
    public function groupByInitials(array $data, string $targetKey = 'key')
    {
        $data = array_map(function($item) use ($targetKey) {
            return array_merge($item, ['initials' => $this->getInitials($item[$targetKey]),]);
        }, $data);
        $data = $this->sortInitials($data);
        return $data;
    }

    /**
     * 按字母排序
     *
     * @param  array  $data
     *
     * @return array
     */
    private function sortInitials(array $data, $default = '#')
    {
        $sortData = [];
        foreach ($data as $key => $value) {
            $sortData[$value['initials']][] = $value;
        }

        // 是否存在 #
        $exits_wei = false;
        if ( !empty($sortData[$default]) ) {
            $exits_wei = true;
            $data_default = $sortData[$default];
        }

        unset($sortData[$default]);
        ksort($sortData);

        if ( $exits_wei ) $sortData[$default] = $data_default;

        return $sortData;
    }

    /**
     * 获取首字母
     *
     * @param  string  $str  汉字字符串
     *
     * @return string 首字母
     */
    private function getInitials($str, $default = '#')
    {
        if ( empty($str) ) {
            return $default;
        }
        $fchar = ord($str{0});
        if ( $fchar >= ord('A') && $fchar <= ord('z') ) {
            return strtoupper($str{0});
        }

        $s1 = iconv('UTF-8', 'GBK//IGNORE', $str);
        $s2 = iconv('GBK//IGNORE', 'UTF-8', $s1);
        $s = $s2 == $str ? $s1 : $str;
        $asc = ord($s{0}) * 256 + ord($s{1}) - 65536;

        if ( $asc >= -20319 && $asc <= -20284 ) {
            return 'A';
        }

        if (
        ($asc >= -20283 && $asc <= -19776)
        ||
        ($asc == -9743) // 亳州市 bozhoushi
        ) {
            return 'B';
        }

        if ( $asc >= -19775 && $asc <= -19219 ) {
            return 'C';
        }

        if (
            ($asc >= -19218 && $asc <= -18711)
            ||
            $asc == -25877 // 氹仔岛
        ) {
            return 'D';
        }

        if ( $asc >= -18710 && $asc <= -18527 ) {
            return 'E';
        }

        if ( $asc >= -18526 && $asc <= -18240 ) {
            return 'F';
        }

        if ( $asc >= -18239 && $asc <= -17923 ) {
            return 'G';
        }

        if ( $asc >= -17922 && $asc <= -17418 ) {
            return 'H';
        }

        if ( $asc >= -17417 && $asc <= -16475 ) {
            return 'J';
        }

        if ( $asc >= -16474 && $asc <= -16213 ) {
            return 'K';
        }

        if (
            ($asc >= -16212 && $asc <= -15641)
            ||
            $asc == -7182 // 泸州市
            ||
            $asc == -6928 // 漯河市
        ) {
            return 'L';
        }

        if ( $asc >= -15640 && $asc <= -15166 ) {
            return 'M';
        }

        if ( $asc >= -15165 && $asc <= -14923 ) {
            return 'N';
        }

        if ( $asc >= -14922 && $asc <= -14915 ) {
            return 'O';
        }

        if (
            ($asc >= -14914 && $asc <= -14631)
            ||
            $asc == -6745 // 濮阳市
        ) {
            return 'P';
        }

        if (
            ($asc >= -14630 && $asc <= -14150)
            ||
            $asc == -7703 // 衢州市
        ) {
            return 'Q';
        }

        if ( $asc >= -14149 && $asc <= -14091 ) {
            return 'R';
        }

        if ( $asc >= -14090 && $asc <= -13319 ) {
            return 'S';
        }

        if ( $asc >= -13318 && $asc <= -12839 ) {
            return 'T';
        }

        if ( $asc >= -12838 && $asc <= -12557 ) {
            return 'W';
        }

        if ( $asc >= -12556 && $asc <= -11848 ) {
            return 'X';
        }

        if ( $asc >= -11847 && $asc <= -11056 ) {
            return 'Y';
        }

        if ( $asc >= -11055 && $asc <= -10247 ) {
            return 'Z';
        }

        return $default;
    }
}
PHP
订阅

评论记录

大好时光
有1条回复记录,下方是回复记录~

评论/回复