在使用拼音码检索汉字的首字符时,对第一类字库的汉字都没有问题,可是对第二类字库的汉字就不行了,好像用汉字与拼音的对应表可以,谁能给我一个对照表及使用方法吗,或者有其它的解决办法,谢谢!

解决方案 »

  1.   

    这个行吗,好象还是有问题
    unit Ut_pysy;interfaceuses
      Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
      StdCtrls;type
      TFm_pysy = class(TForm)
        Search: TEdit;
        Sourcelist: TListBox;
        ResultList: TListBox;
        procedure FormClose(Sender: TObject; var Action: TCloseAction);
        procedure SearchChange(Sender: TObject);
        procedure FormCreate(Sender: TObject);
      private
        { Private declarations }
      public
        { Public declarations }
      end;var
      Fm_pysy: TFm_pysy;
      function GetPYIndexChar( hzchar:string):char;
      function SearchByPYIndexStr( SourceStrs:TStrings;PYIndexStr:string):string;implementation{$R *.DFM}
    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;
    function SearchByPYIndexStr( SourceStrs:TStrings;PYIndexStr:string):string;
    label NotFound;
    var
      i, j :integer;
      hzchar :string;
    begin
      for i:=0 to SourceStrs.Count-1 do
      begin
        for j:=1 to Length(PYIndexStr) do
        begin
          hzchar:=SourceStrs[i][2*j-1]+ SourceStrs[i][2*j];
          if (PYIndexStr[j]<>'?') and (UpperCase(PYIndexStr[j]) <> GetPYIndexChar(hzchar)) then goto NotFound;
        end;
        if result='' then result := SourceStrs[i]
        else result := result + Char(13) + SourceStrs[i];
        NotFound:
      end;
    end;
    procedure TFm_pysy.FormClose(Sender: TObject; var Action: TCloseAction);
    begin
      action:=cafree;
    end;procedure TFm_pysy.SearchChange(Sender: TObject);
    var
      ResultStr:string;
    begin
      ResultStr:='';
      ResultList.Items.Text := SearchByPYIndexStr(Sourcelist.Items, Search.Text);
    end;
    end.
      

  2.   

    找个win98,运行附件的码表生成器->逆转换->找到 拼音输入法的码表文件 在win98/system 下,转换完就得到了
      

  3.   

    我已经得到了winpy.txt文件,该文件为汉字对应的拼音,可是我怎么用到上面的程序中呢?文件为:
    [Description]
    Name=全拼
    MaxCodes=12
    MaxElement=1
    UsedCodes=abcdefghijklmnopqrstuvwxyz
    WildChar=?
    NumRules=3
    [Rule]
    ca4=p10+p20+p30+p40
    ce2=p10+p20
    ce3=p10+p20+p30
    [Text]
    啊a
    阿a
    呵a he
    吖a
    嗄a
    腌a yan
    锕a
    錒a ke
    阿爸aba
    阿昌achang
    厑aes
    爱ai
    矮ai
    ...
      

  4.   

    主要内容就是 [txt]这部分,
    写个简单的小程序,去掉词组部分,得到的就是汉字和拼音的对照表了。
    你可以根据自己的需要转换成其他格式,比如我原来是导成了数据库。另外还有一个多音字的问题,比如
    觉jue jiao
    他好像是这么写的,你也要按照自己的处理。