按asc码来取汉字拼音时总有一些汉字的asc码是错误的或者说是不统一的。布置有没有好的解决方法。

解决方案 »

  1.   

    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(0);
      end;
    end;
      

  2.   

    TO: Wally_wu(韦利)   这样会有一些汉字的拼音取不到的。如:噢、杞、嘌、呤;目前我就知这几个取不到。
    还有没有别的取不到的?另外,汉字的asc编码规则是怎样的,有没有资料提供?
      

  3.   

    有个DLL就是干这个的,你可以去http://www.hu.zj.cninfo.net/~wangyin/myapp/querypy.zip下载,里面有详细说明。不过,多音字就只有查拼音码的编码库了。
      

  4.   

    http://expert.csdn.net/Expert/topic/1030/1030590.xml?temp=9.321231E-02我收藏的回答 
    分要给我哦