C#获取汉字首字母

获取汉字拼音首字母最简单的方法,比前面两篇代码简洁很多

(按汉字首字母排序,支持繁简体(sql语句))讲到如何用SQL语句实现

(C#获取汉字首字母)讲到用C#来实现,建立了一个数组,存放了按汉字笔画顺序排列的汉字首字母,然后将用字符的Unicode编码作索引,到数组中取首字母


以下是完整代码:

 
/// pinyin C# 中取得汉字拼音首字母
/// 
public class pinyin
{
  public static string CVT(string str)
  {
    if (str.CompareTo("吖") < 0)
    {
      string s = str.Substring(0, 1).ToUpper();
      if (char.IsNumber(s, 0))
      {
        return "0";
      }
      else
      {
        return s;
      }
    }
    else if (str.CompareTo("八") < 0)
    {
      return "A";
    }
    else if (str.CompareTo("嚓") < 0)
    {
      return "B";
    }
    else if (str.CompareTo("咑") < 0)
    {
      return "C";
    }
    else if (str.CompareTo("妸") < 0)
    {
        return "D";
    }
    else if (str.CompareTo("发") < 0)
    {
        return "E";
    }
    else if (str.CompareTo("旮") < 0)
    {
        return "F";
    }
    else if (str.CompareTo("铪") < 0)
    {
        return "G";
    }
    else if (str.CompareTo("讥") < 0)
    {
        return "H";
    }
    else if (str.CompareTo("咔") < 0)
    {
        return "J";
    }
    else if (str.CompareTo("垃") < 0)
    {
        return "K";
    }
    else if (str.CompareTo("嘸") < 0)
    {
        return "L";
    }
    else if (str.CompareTo("拏") < 0)
    {
        return "M";
    }
    else if (str.CompareTo("噢") < 0)
    {
        return "N";
    }
    else if (str.CompareTo("妑") < 0)
    {
      return "O";
    }
    else if (str.CompareTo("七") < 0)
    {
      return "P";
    }
    else if (str.CompareTo("亽") < 0)
    {
      return "Q";
    }
    else if (str.CompareTo("仨") < 0)
    {
      return "R";
    }
    else if (str.CompareTo("他") < 0)
    {
      return "S";
    }
    else if (str.CompareTo("哇") < 0)
    {
      return "T";
    }
    else if (str.CompareTo("夕") < 0)
    {
      return "W";
    }
    else if (str.CompareTo("丫") < 0)
    {
      return "X";
    }
    else if (str.CompareTo("帀") < 0)
    {
      return "Y";
    }
    else if (str.CompareTo("咗") < 0)
    {
      return "Z";
    }
    else
    {
      return "0";
    }
  }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你输入的汉子 自动生成五笔代码和拼音代码(简码:取每个汉子的拼音的首字母或者每个汉子的五笔的首字母)本人写了两个存储过程 其实几乎差不多 但是往往啊 会因为一点点小问题导致代码失败 不过 下面的两个存储过程都是成功的 我是因为那么一点点小问题测试了一个上午才搞定了的:对应存储过程 output的参数 一定要先set@=‘’一下才能使用 否则即便是output被赋值了 可以print,但是通过程序代码还是获取不到值的 如下:(具体的在附件里哦,附件里有表数据和存储过程和c#程序代码片段):--drop procedure ChineseCode; ----------一 create procedure ChineseCode(@strkey varchar(30),@rekeysPY varchar(30) output, @rekeysWB varchar(30) output) as declare @keylength int declare @nowstep int declare @temppy varchar(20) declare @tempwb varchar(20) declare @tempkey varchar(4) declare @strpy varchar(30) declare @strwb varchar(30) set @keylength=len(@strkey) set @nowstep=1 set @strpy='' set @strwb='' 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 end set @rekeysPY=@strpy set @rekeysWB=@strwb print @rekeysPY+'--'+@rekeysWB end GO --------------------二 --drop procedure ChineseCode; create procedure ChineseCode ( @strkey varchar(30) , @rekeysPY varchar(30) output, @rekeysWB varchar(30) output) as declare @keylength int declare @i int declare @temppy varchar(10) declare @tempwb varchar(10) declare @tempkey varchar(2) set @keylength=len(@strkey) set @i=1 set @temppy='' set @tempwb='' set @rekeysPY='' set @rekeysWB='' begin while (@i<=@keylength) 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 print @rekeysPY+'--'+@rekeysWB end GO ----------------三 c#代码 PubClass.ContSql db = new MilkDisPatchingManage.PubClass.ContSql(); SqlCommand sqlcmd = new SqlCommand(); sqlcmd.CommandType = CommandType.StoredProcedure; sqlcmd.CommandText = "ChineseCode"; sqlcmd.Parameters.Add("@strkey", SqlDbType.VarChar, 30); sqlcmd.Parameters["@strkey"].Value=this.textBox1.Text.Trim();//.Direction=ParameterDirection.Input; sqlcmd.Parameters.Add("@rekeysPY", SqlDbType.VarChar,30); sqlcmd.Parameters["@rekeysPY"].Direction = ParameterDirection.Output; sqlcmd.Parameters.Add("@rekeysWB", SqlDbType.VarChar,30); sqlcmd.Parameters["@rekeysWB"].Direction = ParameterDirection.Output; int i= db.ExtCom(sqlcmd); this.textBox2.Text = sqlcmd.Parameters["@rekeysPY"].Value.ToString(); this.textBox3.Text = sqlcmd.Parameters["@rekeysWB"].Value.ToString(); db.CloseCon();

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值