• 获取人员姓名首拼


     #region 获取人员姓名首拼
            /// <summary>
            /// 获取姓名拼音的缩写
            /// </summary>
            /// <param name="str"></param>
            /// <returns></returns>
            public static string GetPYString(string str)
            {
                str = System.Text.RegularExpressions.Regex.Replace(str, @"\s", "");//处理姓名中间的空格
                string tempStr = "";
                foreach (char c in str)
                {
                    if ((int)c >= 33 && (int)c <= 126)
                    {//字母和符号原样保留 
                        tempStr += c.ToString();
                    }
                    else
                    {//累加拼音声母 
    
                        try
                        {
                            tempStr += GetPYChar(c.ToString());
                        }
                        catch (Exception e)
                        {
                            string t = e.Message;
                        }
                    }
                }
                return tempStr;
            }
            /// <summary>
            /// 返回汉子的首个字母
            /// </summary>
            /// <param name="c"></param>
            /// <returns></returns>
            private static string GetPYChar(string c)
            {
                byte[] array = new byte[2];
                array = System.Text.Encoding.Default.GetBytes(c);
                int i = (short)(array[0] - '\0') * 256 + ((short)(array[1] - '\0'));
                if (i < 0xB0A1) return "*";
                if (i < 0xB0C5) return "a";
                if (i < 0xB2C1) return "b";
                if (i < 0xB4EE) return "c";
                if (i < 0xB6EA) return "d";
                if (i < 0xB7A2) return "e";
                if (i < 0xB8C1) return "f";
                if (i < 0xB9FE) return "g";
                if (i < 0xBBF7) return "h";
                if (i < 0xBFA6) return "g";
                if (i < 0xC0AC) return "k";
                if (i < 0xC2E8) return "l";
                if (i < 0xC4C3) return "m";
                if (i < 0xC5B6) return "n";
                if (i < 0xC5BE) return "o";
                if (i < 0xC6DA) return "p";
                if (i < 0xC8BB) return "q";
                if (i < 0xC8F6) return "r";
                if (i < 0xCBFA) return "s";
                if (i < 0xCDDA) return "t";
                if (i < 0xCEF4) return "w";
                if (i < 0xD1B9) return "x";
                if (i < 0xD4D1) return "y";
                if (i < 0xD7FA) return "z";
                return "*";
            }
            #endregion
  • 相关阅读:
    网络优化改进
    图像识别和卷积神经网路案例的实现
    卷积神经网络和图像识别
    ANA网络分析
    大数阶乘
    HDU 1002 A + B Problem II (大数加法)
    HDU 1232 畅通工程 (并查集)
    HDU 1231 最大连续子序列 (dp)
    HDU 2546 饭卡 (dp)
    HDU 1203 I NEED A OFFER! (dp)
  • 原文地址:https://www.cnblogs.com/yc1224/p/16145363.html
Copyright © 2020-2023  润新知