我想了一个办法,在数据库里增加一个字段,里面为每个汉字的拼音韵母,再利用这个字段索引。(如:在ComBoBox中输入b,会自动弹出下拉列表,在列表中显示如b11,b12,北京,北京天安门,在接着输入j,此时输入框为bj,则在下拉列表框中显示北京,北京天安门)在其它的编辑框中是可以的,但是我想直接在ComBoBox下拉列表框中输入字母时,总有问题,不是下拉列表有重复索引,就是达不到这种效果。请问该怎么写?
谢谢各位。

解决方案 »

  1.   

    在COMBOBOX.ONKEYUP 事件中加查询语句,然后将结果动态添加到COMBOBOX中
      

  2.   

    在Delphi中用拼音首字符序列来实现检索功能
     
    作者:夏昆    教程来源:网络    点击数:14    更新时间:2004-11-10 【字体:小 大】    热     
     
    在日常工作和生活中我们经常使用电子记事本查找个人通讯录信息,或在单位的应用程序中查询客户档案或业务资料,这个过程中往往需要输入大量的汉字信息,对于熟悉计算机的人这已经是一件头疼的事,那些不太熟悉计算机或根本不懂汉字输入的用户简直就望而生畏。作为对数据检索技术的一种新的尝试,作者探索使用汉字拼音的首字符序列作为检索关键字,这样,用户不必使用汉字,只须简单地键入要查询信息的每个汉字的拼音首字符即可。比如你想查找关键字“中国人民银行”,你只需要输入“zgrmyh”。作者希望通过下面的例子,为广大计算机同行起一个抛砖引玉的作用,让我们开发的程序更加便捷、好用。 ---- 原理很简单,找出汉字表中拼音首字符分别为“A”至“Z”的汉字内码范围,这样,对于要检索的汉字只需要检查它的内码位于哪一个首字符的范围内,就可以判断出它的拼音首字符。 ---- 程序更简单,包括3个控件:一个列表存放着所有待检索的信息;一个列表用于存放检索后的信息;一个编辑框用于输入检索关键字(即拼音首字符序列)。详细如下: ---- 1.进入Delphi创建一个新工程:Project1 ---- 2.在Form1上创建以下控件并填写属性: 控件类型      属性名称  属性值
    Edit           Name      Search
    ListBox        Name      SourceList
    Items      输入一些字符串,如姓名等,用于提供检索数据
    ListBox        Name      ResultList
     ---- 3.键入以下两个函数 // 获取指定汉字的拼音索引字母,如:“汉”的索引字母是“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(0);
      end;
    end;// 在指定的字符串列表SourceStrs中检索符合拼音索引字符串
    PYIndexStr的所有字符串,并返回。
    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;4.增加编辑框Search的OnChange事件:
    procedure TForm1.SearchChange(Sender: TObject);
    var ResultStr:string;
    begin
      ResultStr:='';
      ResultList.Items.Text := SearchByPYIndexStr
    (Sourcelist.Items, Search.Text);
    end; 
     ---- 5.编译运行后,在编辑框Search中输入要查询字符串的拼音首字符序列,检索结果列表ResultList就会列出检索到的信息,检索中还支持“?”通配符,对于难以确定的的文字使用“?”替代位置,可以实现更复杂的检索。
      

  3.   

    function GetPYIndexChar( hzchar:string):char;这个函数不全啊。
    试了几个字
    乁,噢   都没有
      

  4.   


    EBE7这个字也没有.
    有没有全一点的?
      

  5.   

    有点偏题了吧。我说的要是在ComBoBox中实现。请问要怎么实现???谢谢各位,热情的发言。
      

  6.   

    sunnysheng(sunnysheng) ( ) 信誉:87  2004-12-02 13:58:00  得分: 0  
     
     
       有点偏题了吧。我说的要是在ComBoBox中实现。请问要怎么实现???谢谢各位,热情的发言。
      
     
    呵呵,xufenglong(天天向上) ( )的回复已经说得很明白了。原理行得通,实现起来也就容易了。我只是发现有些字的编码不在他所列举的范围内所以才提出疑问。
      

  7.   

    是拼音声母吧!
    获取拼音的首字母要还要用到二组字库:
    我是用DLL写的,如果需要的话请留下E-mail
      

  8.   

    可在combobox的OnChange中写事件,然后根据输入的拼音首字母,动态的向combobox的下拉菜单中赋值
      

  9.   

    谢谢各位。
      To:shunbing谢谢你的帮助我的E-Mail:[email protected]
         另外,你说的在OnChange中写事件。我的代码如下:
    procedure TForm2.ComboBox1Change(Sender: TObject);
    var
      s:string;
    begin
      ADOQuery1.Close;
      ADOQuery1.SQL.Clear;
      ADOQuery1.sql.Add('select 名称 from lj where 索引 like '''+ComBoBox1.Text +'%''');
      ADOQuery1.Open;
      s:= ComBoBox1.Text;
      ComBoBox1.Clear;
      while not ADOQuery1.Eof do
      begin
        //if -1 = ComBoBox1.Items.IndexOf(ADOQuery1.FieldByName('名称').AsString) then
         // (ADOQuery1.FieldByName('名称').AsString);
        ComBoBox1.Items.Add(ADOQuery1.FieldByName('名称').AsString);
        ADOQuery1.Next;
      end;
      ComBoBox1.DroppedDown:=false;
      ComBoBox1.DroppedDown:=true;
      ComBoBox1.SelLength := Length(s);
      ComBoBox1.SelStart :=  Length(s);
      我总感觉不是太好,有闪烁。希望能得到帮助。