2个不错的通配符比较函数
2008-04-09 04:24:43来源:互联网 阅读 ()
近日在和朋友讨论 MaskMatch 时偶得2个不错的算法。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
函数1 只支持''''*'''',''''?''''模糊匹配。速度比采用递归算法的快近2倍,比TMask方法快很多。
函数2 完全支持正规表达式。速度于之前的相同。(不会正规表达式的朋友慎用)
// ===========================
// Funtion 1
// ===========================
// Check if the string can match the wildcard. It can be used for unicode strings as well!
// C: 2004-07-24 | M: 2004-07-24
function MaskMatch(const aPattern, aSource: string): Boolean;
var
StringPtr, PatternPtr: PChar;
StringRes, PatternRes: PChar;
begin
Result := False;
StringPtr := PChar(UpperCase(aSource));
PatternPtr := PChar(UpperCase(aPattern));
StringRes := nil;
PatternRes := nil;
repeat
repeat // ohne vorangegangenes "*"
case PatternPtr^ of
#0 : begin
Result := StringPtr^ = #0;
if Result or (StringRes = nil) or (PatternRes = nil) then Exit;
StringPtr := StringRes;
PatternPtr := PatternRes;
Break;
end;
''''*'''': begin
Inc(PatternPtr);
PatternRes := PatternPtr;
Break;
end;
''''?'''': begin
if StringPtr^ = #0 then Exit;
Inc(StringPtr);
Inc(PatternPtr);
end;
else begin
if StringPtr^ = #0 then Exit;
if StringPtr^ <> PatternPtr^ then
begin
if (StringRes = nil) or (PatternRes = nil) then Exit;
StringPtr := StringRes;
PatternPtr := PatternRes;
Break;
end else
begin
Inc(StringPtr);
Inc(PatternPtr);
end;
end;
end;
until False;
repeat // mit vorangegangenem "*"
case PatternPtr^ of
#0 : begin
Result := True;
Exit;
end;
''''*'''': begin
Inc(PatternPtr);
PatternRes := PatternPtr;
end;
''''?'''': begin
if StringPtr^ = #0 then Exit;
Inc(StringPtr);
Inc(PatternPtr);
end;
else begin
repeat
if StringPtr^ = #0 then Exit;
if StringPtr^ = PatternPtr^ then Break;
Inc(StringPtr);
until False;
Inc(StringPtr);
StringRes := StringPtr;
Inc(PatternPtr);
Break;
end;
end;
until False;
until False;
end;
// ===========================
// Funtion 2
// ===========================
function _MatchPattern(aPattern, aSource: PChar): Boolean;
begin
Result := True;
while (True) do
begin
case aPattern[0] of
#0 : begin
//End of pattern reached.
Result := (aSource[0] = #0); //TRUE if end of aSource.
Exit;
end;
''''*'''': begin //Match zero or more occurances of any char.
if (aPattern[1] = #0) then
begin
//Match any number of trailing chars.
Result := True;
Exit;
end else
Inc(aPattern);
while (aSource[0] <> #0) do
begin
//Try to match any substring of aSource.
if (_MatchPattern(aSource, aPattern)) then
begin
Result := True;
Exit;
end;
//Continue testing next char...
Inc(aSource);
end;
end;
''''?'''': begin //Match any one char.
if (aSource[0] = #0) then
begin
Result := False;
Exit;
end;
//Continue testing next char...
Inc(aSource);
Inc(aPattern);
end;
''''['''': begin //Match given set of chars.
if (aPattern[1] in [#0,''''['''','''']'''']) then
begin
//Invalid Set - So no match.
Result := False;
Exit;
end;
if (aPattern[1] = ''''^'''') then
begin
//Match for exclusion of given set...
Inc(aPattern, 2);
Result := True;
while (aPattern[0] <> '''']'''') do
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:注册文件类型,设置文件图标
- Delphi学习:2个不错的通配符比较函数 2008-02-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash