有类似的,在www.codeproject.com的Edit条目下找。
原控件是输入英文比如,输入'chi',识别为'china',
但可以改为中文,开个二维数组,读入字典文件,字典文件
存放数组的各元素值,一维为拼音字头,一维为对应汉字。思路而已,应该容易实现。

解决方案 »

  1.   

    首先的有资料库 然后select * from 资料库 where input like '%12345%'
    不过建立资料库有点难
      

  2.   

    我想是很简单的汉字都有区位码的,,
    比如,,汉字 中  
    啊---黯 是一个段
    八---不  又是一短
    我输入  ab是,,我来查找 我的 CString arString[MAX] 
    arString[0]的有一个字符 是不是在 “啊---黯” 而且,也有一个字符是在 
    “八---不” 段
      

  3.   

    首先汉字的内码是有规律的。即GBK。 你可以在系统目录下找到这个文件:windows.gbk  里边的字对应的行和列就是内码。比如啊,0xb0,0xa1 我们用的其实的gb2312-80的那部分。汉字总共6763个,其中常用字3755个,称一级字。就是前面的3755个汉字。这些字中前1188(具体数字记不清了)是按拼音排列的; 后面的汉字是按笔画排列的。后面的3008是不常用字,即二级字. 以你的情况看据内码计算可能会少字最好是做一个对应表:可以写成文件或在程序中用静态数组解决。
     总之要建立一个关联表。  你可以这样做:利用输入法转换器逆转换成汉字--拼音表
                   然后写个小程序处理掉多余的字符,只剩你所需要的
                   查表找出你所要的结果。
       还有问题mail to [email protected]
      

  4.   

    汉字的编码 0xb0,0xa1 一直到多少?
      

  5.   

    what`s the meaning of "up"
      

  6.   


    // 获取指定汉字的拼音索引字母,如:“汉”的索引字母是“H”
    function GetPYIndexChar( hzchar:string):char;
    begin
      case WORD(hzchar[1]) shl 8 + WORD(hzchar[2]) of
        $B0A1..$B0C4 : result := 'A';
        $B0C5..$B2C0 : result := 'B';
        $B2C1..$B4ED : result := 'C';
        $B4EE..$B6E9 : result := 'D';
        $B6EA..$B7A1 : result := 'E';
        $B7A2..$B8C0 : result := 'F';
        $B8C1..$B9FD : result := 'G';
        $B9FE..$BBF6 : result := 'H';
        $BBF7..$BFA5 : result := 'J';
        $BFA6..$C0AB : result := 'K';
        $C0AC..$C2E7 : result := 'L';
        $C2E8..$C4C2 : result := 'M';
        $C4C3..$C5B5 : result := 'N';
        $C5B6..$C5BD : result := 'O';
        $C5BE..$C6D9 : result := 'P';
        $C6DA..$C8BA : result := 'Q';
        $C8BB..$C8F5 : result := 'R';
        $C8F6..$CBF9 : result := 'S';
        $CBFA..$CDD9 : result := 'T';
        $CDDA..$CEF3 : result := 'W';
        $CEF4..$D188 : result := 'X';
        $D1B9..$D4D0 : result := 'Y';
        $D4D1..$D7F9 : result := 'Z';
      else
        result := char(32);
      end;
    end;procedure TMainForm.btnConvertClick(Sender: TObject);
    var
      I: Integer;
      PY: string;
      s: string;
    begin
      s := '' ;
      I := 1;
      while I <= Length(ChineseEdt.Text) do
      begin
        PY := Copy(ChineseEdt.Text, I , 1);
        if PY >= Chr(128) then
        begin
          Inc(I);
          PY := PY + Copy(ChineseEdt.Text, I , 1);
          s := s + GetPYIndexChar(PY);
        end
        else
          s := s + PY;
        Inc(I);
      end;
      PYEdt.Text := s;
    end;
      

  7.   

    struct BIANMA
    {
    unsigned short int _begin;
    unsigned short int _end;
    unsigned char _char;
    };
    BIANMA BianMaBiao[23]=
    {
    {0xb0a1,0xb0c4,'A'},
    {0xB0C5,0xB2C0,'B'},
        {0xB2C1,0xB4ED,'C'},
        {0xB4EE,0xB6E9,'D'},
        {0xB6EA,0xB7A1,'E'},
        {0xB7A2,0xB8C0,'F'},
        {0xB8C1,0xB9FD,'G'},
        {0xB9FE,0xBBF6,'H'},
        {0xBBF7,0xBFA5,'J'},
        {0xBFA6,0xC0AB,'K'},
        {0xC0AC,0xC2E7,'L'},
        {0xC2E8,0xC4C2,'M'},
        {0xC4C3,0xC5B5,'N'},
        {0xC5B6,0xC5BD,'O'},
        {0xC5BE,0xC6D9,'P'},
        {0xC6DA,0xC8BA,'Q'},
        {0xC8BB,0xC8F5,'R'},
        {0xC8F6,0xCBF9,'S'},
        {0xCBFA,0xCDD9,'T'},
        {0xCDDA,0xCEF3,'W'},
        {0xCEF4,0xD188,'X'},
        {0xD1B9,0xD4D0,'Y'},
        {0xD4D1,0xD7F9,'Z'}
    };
      

  8.   

    嘿嘿,我也不知道!
    不过可以请教一下 PClog 的作者。
    那是个间谍。
      

  9.   

    现在插播一条广告:一个既简单有复杂的问题 (关于 memfile )http://www.csdn.net/expert/topic/755/755278.xml?temp=.8945581