• 获取汉字的首字母


    因为项目需要,根据汉字的首字母对一个字段进行排序。所以有了下面这个方法。

      先说下这个方法存在的问题和原理。

        第一这个方法是根据汉字的gb2312 编码来确定首字母的。这里有必要去了解一下gb2312,他分了区位码,可以自己去,区码+oxA0加位码+oxA0构成了gb2312编码。

        所以我们要做的就是获得首字母,转gb2312 转 区位码。 对于常见字这里是区位码是按照拼音顺序排列。一些生僻字就是按笔画顺序排列的。对于这样的汉字下面的方法就无能为力了。

    using System;
    using System.Collections.Generic;
    using System.Text;
    
    namespace Samddy.Jincaizi.WXCommon
    {
        public class FirstLetterHelper
        {
            public static string FirstLetter(byte[] bg2312)
            {
                if (bg2312.Length != 2)
                    return "Error";
                string strLetter = "Zz";
                byte b1 = bg2312[0];
                byte b2 = bg2312[1];
                string s1 = String.Format("{0:D2}", b1 - 160);
                string s2 = String.Format("{0:D2}", b2 - 160);
                int nCode = Convert.ToInt32(s1 + s2);
                if (nCode >= 1601 && nCode < 1637) strLetter = "A";
                if (nCode >= 1637 && nCode < 1833) strLetter = "B";
                if (nCode >= 1833 && nCode < 2078) strLetter = "C";
                if (nCode >= 2078 && nCode < 2274) strLetter = "D";
                if (nCode >= 2274 && nCode < 2302) strLetter = "E";
                if (nCode >= 2302 && nCode < 2433) strLetter = "F";
                if (nCode >= 2433 && nCode < 2594) strLetter = "G";
                if (nCode >= 2594 && nCode < 2787) strLetter = "H";
                if (nCode >= 2787 && nCode < 3106) strLetter = "J";
                if (nCode >= 3106 && nCode < 3212) strLetter = "K";
                if (nCode >= 3212 && nCode < 3472) strLetter = "L";
                if (nCode >= 3472 && nCode < 3635) strLetter = "M";
                if (nCode >= 3635 && nCode < 3722) strLetter = "N";
                if (nCode >= 3722 && nCode < 3730) strLetter = "O";
                if (nCode >= 3730 && nCode < 3858) strLetter = "P";
                if (nCode >= 3858 && nCode < 4027) strLetter = "Q";
                if (nCode >= 4027 && nCode < 4086) strLetter = "R";
                if (nCode >= 4086 && nCode < 4390) strLetter = "S";
                if (nCode >= 4390 && nCode < 4558) strLetter = "T";
                if (nCode >= 4558 && nCode < 4684) strLetter = "W";
                if (nCode >= 4684 && nCode < 4925) strLetter = "X";
                if (nCode >= 4925 && nCode < 5249) strLetter = "Y";
                if (nCode >= 5249 && nCode < 5590) strLetter = "Z";
                return strLetter;
            }
        }
    }
  • 相关阅读:
    win7服务器从本地粘贴的文件,粘贴卡死
    AOP面向切面编程
    静态代理和动态代理
    查询数据库中第n行数据
    记录我的成长
    路径总和,双重递归
    java Queue 常用方法(持续更新)
    对称二叉树
    Linux学习之五——Linux虚拟机文件系统
    Linux学习之四——命令运行机制及查看命令帮助
  • 原文地址:https://www.cnblogs.com/wxzl/p/2451237.html
Copyright © 2020-2023  润新知