信息发布软件,b2b软件,广告发布软件

标题: Delphi程序小功能大用处居然可以用拼音完成测试功能 [打印本页]

作者: 群发软件    时间: 2017-8-9 22:43
标题: Delphi程序小功能大用处居然可以用拼音完成测试功能
本帖最后由 群发软件 于 2017-8-9 22:47 编辑

在日常工作和生活中我们经常使用电子记事本查找个人通讯录信息,或在单位的应用程序中查询客户档案或业务资料,这个过程中往往需要输入大量的汉字信息,对于熟悉计算机的人这已经是一件头疼的事,那些不太熟悉计算机或根本不懂汉字输入的用户简直就望而生畏。作为对数据检索技术的一种新的尝试,作者探索使用汉字拼音的首字符序列作为检索关键字,这样,用户不必使用汉字,只须简单地键入要查询信息的每个汉字的拼音首字符即可。比如你想查找关键字“中国人民银行”,你只需要输入“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[2*j-1]            + SourceStrs[2*j];            if (PYIndexStr[j]<>'?') and            (UpperCase(PYIndexStr[j]) <>            GetPYIndexChar(hzchar)) then goto NotFound;            end;            if result=' then result := SourceStrs            else result := result + Char            (13) + SourceStrs;            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就会列出检索到的信息,检索中还支持“?”通配符,对于难以确定的的文字使用“?”替代位置,可以实现更复杂的检索。


Delphi程序小功能大用处居然可以用拼音完成测试功能 b2b软件


SELECT * FROM user WHERE name LIKE ';%三%';
将会把name为“张三”,“三脚猫”,“唐三藏”等等有“三”的全找出来;
其中LIKE ';%三%'明显多了个分号“;”,这还能搜索得出来么?估计是编辑器编译的缘故。
======重新编辑文如下:
在进行数据库查询时,有完整查询和模糊查询之分。
一般模糊语句如下:
SELECT 字段 FROMWHERE 某字段 Like 条件
其中关于条件,SQL提供了四种匹配模式:
1,%:表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。
比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'
将会把u_name为“张三”,“张猫三”、“三脚猫”,“唐三藏”等等有“三”的记录全找出来。
另外,如果需要找出u_name中既有“三”又有“猫”的记录,请使用and条件
SELECT * FROM [user] WHERE u_name LIKE '%三%' AND u_name LIKE '%猫%'

若使用 SELECT * FROM [user] WHERE u_name LIKE '%三%猫%'
虽然能搜索出“三脚猫”,但不能搜索出符合条件的“张猫三”。
2,_: 表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:
比如
SELECT * FROM [user] WHERE u_name LIKE '_三_'

只找出“唐三藏”这样u_name为三个字且中间一个字是“三”的;
再比如 SELECT * FROM [user] WHERE u_name LIKE '三__';
只找出“三脚猫”这样name为三个字且第一个字是“三”的;
3,[ ]:表示括号内所列字符中的一个(类似正则表达式)。指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。
比如
SELECT * FROM [user] WHERE u_name LIKE '[张李王]三'

将找出“张三”、“李三”、“王三”(而不是“张李王三”);
如 [ ] 内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”
SELECT * FROM [user] WHERE u_name LIKE '老[1-9]'

将找出“老1”、“老2”、……、“老9”;
4,[^ ] :表示不在括号所列之内的单个字符。其取值和 [] 相同,但它要求所匹配对象为指定字符以外的任一个字符。
比如
SELECT * FROM [user] WHERE u_name LIKE '[^张李王]三'

将找出不姓“张”、“李”、“王”的“赵三”、“孙三”等;
SELECT * FROM [user] WHERE u_name LIKE '老[^1-4]';

将排除“老1”到“老4”,寻找“老5”、“老6”、……
5,查询内容包含通配符时
由于通配符的缘故,导致我们查询特殊字符“%”、“_”、“[”的语句无法正常实现,而把特殊字符用“[ ]”括起便可正常查询。据此我们写出以下函数:
function sqlencode(str)str=replace(str,"[","[[]") '此句一定要在最前str=replace(str,"_","[_]")str=replace(str,"%","[%]")sqlencode=strend function

作者: cd0010    时间: 2017-8-11 03:19
有竞争才有进步嘛
作者: ye112219    时间: 2017-8-11 13:47
卖家,技术过硬,服务过好,就像巴黎欧莱雅,你值得拥有
作者: mm5216299    时间: 2017-8-16 15:49
很好,客服很耐心,谢谢!
作者: anleeycn    时间: 2017-8-18 04:11
常好,技术也好,以后有问题就选这家了,支持
作者: ctbvip    时间: 2017-8-23 00:39
心,一直回答我。我自己一直弄不懂他很耐心。
作者: nidalma001    时间: 2017-8-23 09:23
少去评论但这样的卖家你买到的不仅仅是商品更多的是感动(这是用钱无法衡量的)!网站做过不少但都是草草收场。从开始的第一句话到交易成功这态度和耐心无论是客服还是技术有问必答有求必应!我想说的是这样的做事如此负责态度不成功都难!!这是我体验过最好的对话和服务处处都是为对方着想在这如此浮躁的时代依然有暖心感动!再次感谢!祝生意兴隆!还会继续合作!!
作者: 小痞子    时间: 2017-8-24 08:08
平可以
作者: znl001    时间: 2017-8-27 04:21
站设计,特别要赞一下183533号设计师,认真负责有耐心,后期还有要请教的地方希望一如既往的支持哦!
作者: huangge    时间: 2017-8-29 13:25
很快,给力卖家赞一个!!!
作者: wbd902    时间: 2017-8-31 05:22
说不错,给好评吧
作者: 429187535    时间: 2017-9-1 08:01
很好,非常感谢18号和3号客服耐心详细的解释和教导
作者: yiyi2014    时间: 2017-9-1 21:36
蛋和18号笨蛋的工号,态度很好很细心很赞
作者: qiaozong01    时间: 2017-9-3 08:37
务非常棒,而且非常耐心的解决我们的各种问题,非常的敬业,虽然这是个简单的小业务,但是卖家细心的为我这边服了一上午,真的不知道怎么表达对店家的服务精神敬佩,起码在这里真的不能看级别高低,要看就看卖家是不是真心为你服务,服务好才是硬道理!!这个卖家真的不错,5分好评!
作者: zzjiuzi008    时间: 2017-9-6 10:21
谢谢,共同发展




欢迎光临 信息发布软件,b2b软件,广告发布软件 (http://www.postbbs.com/) Powered by Discuz! X3.2