C# 获取汉字的拼音首字母
/// <summary>
/// 在指定的字符串列表CnStr中检索符合拼音索引字符串
/// </summary>
/// <param name="CnStr">汉字字符串</param>
/// <returns>相对应的汉语拼音首字母串</returns>
public static string GetSpellCode(string CnStr) {
string strTemp="";
int iLen=CnStr.Length;
int i=0;
for (i=0;i<=iLen-1;i++) {
strTemp+=GetCharSpellCode(CnStr.Substring(i,1));
}
return strTemp;
}
/// <summary>
/// 得到一个汉字的拼音第一个字母,如果是一个英文字母则直接返回大写字母
/// </summary>
/// <param name="CnChar">单个汉字</param>
/// <returns>单个大写字母</returns>
private static string GetCharSpellCode(string CnChar) {
long iCnChar;
byte[] ZW = System.Text.Encoding.Default.GetBytes(CnChar);
//如果是字母,则直接返回
if (ZW.Length==1) {
return CnChar.ToUpper();
}
else {
// get the array of byte from the single char
int i1 = (short)(ZW[0]);
int i2 = (short)(ZW[1]);
iCnChar = i1*256+i2;
}
// iCnChar match the constant
if ((iCnChar>=45217) && (iCnChar<=45252)) {
return "A";
}
else if ((iCnChar>=45253) && (iCnChar<=45760)) {
return "B";
} else if ((iCnChar>=45761) && (iCnChar<=46317)) {
return "C";
} else if ((iCnChar>=46318) && (iCnChar<=46825)) {
return "D";
} else if ((iCnChar>=46826) && (iCnChar<=47009)) {
return "E";
} else if ((iCnChar>=47010) && (iCnChar<=47296)) {
return "F";
} else if ((iCnChar>=47297) && (iCnChar<=47613)) {
return "G";
} else if ((iCnChar>=47614) && (iCnChar<=48118)) {
return "H";
} else if ((iCnChar>=48119) && (iCnChar<=49061)) {
return "J";
} else if ((iCnChar>=49062) && (iCnChar<=49323)) {
return "K";
} else if ((iCnChar>=49324) && (iCnChar<=49895)) {
return "L";
} else if ((iCnChar>=49896) && (iCnChar<=50370)) {
return "M";
}else if ((iCnChar>=50371) && (iCnChar<=50613)) {
return "N";
} else if ((iCnChar>=50614) && (iCnChar<=50621)) {
return "O";
} else if ((iCnChar>=50622) && (iCnChar<=50905)) {
return "P";
} else if ((iCnChar>=50906) && (iCnChar<=51386)) {
return "Q";
} else if ((iCnChar>=51387) && (iCnChar<=51445)) {
return "R";
} else if ((iCnChar>=51446) && (iCnChar<=52217)) {
return "S";
} else if ((iCnChar>=52218) && (iCnChar<=52697)) {
return "T";
} else if ((iCnChar>=52698) && (iCnChar<=52979)) {
return "W";
} else if ((iCnChar>=52980) && (iCnChar<=53640)) {
return "X";
} else if ((iCnChar>=53689) && (iCnChar<=54480)) {
return "Y";
} else if ((iCnChar>=54481) && (iCnChar<=55289)) {
return "Z";
} else
return ("?");
}
C# 获取汉字的拼音首字母的更多相关文章
- (转载)delphi中获取汉字的拼音首字母
delphi中获取汉字的拼音首字母1.py: array[216..247] of string = ({216}'CJWGNSPGCGNESYPB' + 'TYYZDXYKYGTDJNMJ' + ' ...
- sql获取汉字的拼音首字母的函数
ql获取汉字的拼音首字母 if exists (select * from sysobjects where id = object_id(N'[fn_ChineseToSpell]') and ...
- C# 获取汉字的拼音首字母和全拼(含源码)
C# 获取汉字的拼音首字母 一种是把所有中文字符集合起来组成一个对照表:另一种是依照汉字在Unicode编码表中的排序来确定拼音的首字母.碰到多音字时就以常用的为准(第一种方法中可以自行更改,方法为手 ...
- 获取汉字的拼音首字母--pinyin
var pinyin = (function (){ var Pinyin = function (ops){ this.initialize(ops); }, options = { checkPo ...
- sql获取汉字的拼音首字母
if exists (select * from sysobjects where id = object_id(N'[fn_ChineseToSpell]') and xtype in (N'FN' ...
- SqlServer 笔记二 获取汉字的拼音首字母
一.该函数传入字符串,返回数据为:如果为汉字字符,返回该字符的首字母,如果为非汉字字符,则返回本身. 二.用到的知识点:汉字对应的UNICODE值,汉字的排序规则. 三.数据库函数: )) ) AS ...
- SqlServer 获取汉字的拼音首字母
一.该函数传入字符串,返回数据为:如果为汉字字符,返回该字符的首字母,如果为非汉字字符,则返回本身.二.用到的知识点:汉字对应的UNICODE值,汉字的排序规则.三.数据库函数: CREATE FUN ...
- C#获取包括一二级汉字的拼音 首字母
C#获取包括一二级汉字的拼音 首字母 声母 汉字拼音转换 using System; using System.Collections.Generic; using System.Linq; usin ...
- js汉字转拼音首字母
js汉字转拼音首字母 2018-04-09 阅读 1018 收藏 1 原链:segmentfault.com 分享到: 前端必备图书<JavaScript设计模式与开发实践> > ...
随机推荐
- NSOperation使用系统提供子类的方法--处理复杂任务
//创建一个队列 NSOperationQueue *operation=[[NSOperationQueue alloc]init]; //把任务放在NSBlockOperation里面 NSBlo ...
- 10. Android框架和工具之 AppMsg(消息提示)
1. AppMsg 优雅的弹出类似Toast的消息提示,支持3种状态Alert(警告),Confirm(确认)以及Info(消息). 2. AppMsg使用: (1)AppMsg下载地址 ...
- 正试图在 os 加载程序锁内执行托管代码。不要尝试在 DllMain 或映像初始化函数内运行托管代码
来自:http://www.cnblogs.com/lcxu2/archive/2011/01/16/2004016.html 正试图在 os 加载程序锁内执行托管代码.不要尝试在 DllMain 或 ...
- iOS 犄角旮旯的知识
1.全局变量 static NSInteger kImageHeight = 300; #define kImageHeight 300 2.通知中心 开始编辑 UITextViewTextDidBe ...
- windows更新npm
今天遇到一个项目需要更新npm的版本,搜了一下如何更新npm的方法,有的人说直接重装node,npm版本就会是最新的,真是无力吐槽,要是每次更新都得这么麻烦还得了,我觉得一定有更好更简单的方法,最后果 ...
- LeetCode 287
Find the Duplicate Number Given an array nums containing n + 1 integers where each integer is betwee ...
- Service Discovery with Apache Curator
Curator的介绍 Curator就是Zookeeper的一个客户端工具(不知道Zookeeper的同学可以到http://www.ibm.com/developerworks/cn/opensou ...
- CF 335B - Palindrome 区间DP
335B - Palindrome 题目: 给出一个字符串(均有小写字母组成),如果有长度为100的回文子串,输出该子串.否则输出最长的回文子串. 分析: 虽然输入串的长度比较长,但是如果存在单个字母 ...
- 有一种风格,叫做 Low Poly 3D
原作:Simon阿文 杂交编辑者:RhinoC 个人更推崇使用第二款神器 ImageTriangulator :http://www.conceptfarm.ca/2013/port ...
- Codevs 1287 矩阵乘法&&Noi.cn 09:矩阵乘法(矩阵乘法练手题)
1287 矩阵乘法 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Description 小明最近在为线性代数而头疼, ...