开发者社区


C++/C | Java | .Net/Windows | Linux/Unix | 开源 | 其他
首页 - 编程
编程
全文搜索:   

在Perl中构造查询引擎
作者: ZDNet China
2004-01-29 10:25:56


本文译自TechRepublic,未经许可请勿转载

  

如果用户被允许在Perl中用自己的语言详细的直接询问那么Perl分析文本的能力将被大大地增强。这个技术允许记录文件的复形处理并允许其他程序的输出。

   下面的程序将执行在CSV文件上任意复形查询,比如,通过电子表格程序运行的进程。假设文件的第一行包括了文件的列表。简单的说,程序将从standard in中读取输出数据。

use strict;
use Text::ParseWords;

# get header line
my $header = <STDIN>;

# get field names
my @fieldNames = quotewords(",", 0, $header);

# strip leading & trailing spaces (if any), replace internal spaces with underscore
@fieldNames = map {s/^s+//; s/s+$//; s/s+/_/g; $_} @fieldNames;

my @fields; # where field data will be stored

# create access functions
for (my $i = 0; $i < @fieldNames; $i++)
{
    no strict 'refs';

    my $name = $fieldNames[$i];

    eval "sub $name () { $fields[$i] }";     # create access subroutine
    *{lc $name} = *{uc $name} = $name; # make upper and lower case aliases
}

# compile user's query
my $code = "sub Query { " . join(" and ", @ARGV) . " }";
eval $code.1 or die "Error: $@ In query string: $code ";

# print the header line (field names)
print $header;

# process each line
while (<STDIN>)
{
    @fields = quotewords(",", 0, $_);
    print if Query();
}

   使用Perl来变异和执行代码可以使写和使用强大的滤波器程序变得简单明了。



责任编辑:李宁

欢迎评论投稿

声明:
Builder.com.cn(原ZDNet China应用开发频道)原创文章版权所有,未经许可严禁转载,且不构成投资建议。
近期相关报道:
实用技术文档
J2me XML
C/C++ C#
Java Oracle
Mysql .Net
VB.NET CSS
SQL Server 数据库
SQL UNIX
Linux Jsp
PHP Perl
Javascript IIS
XHTML ColdFusion
ASP/ASP.NET Apache
AJAX
订阅技术邮件
订阅"技术圈"杂志!请在下面选择您感兴趣的专题,填写e-mail地址,然后按订阅按钮:
应用开发管理
VS.NET 周刊
Database 周刊
WEB Service周刊
JAVA 周刊
IT 认证
Windows服务器周刊
互联网开发
当Windows Server 2008专家得5000元现金大奖
CNET NETWORKS 中国: 爱卡汽车网 | CNET科技资讯网 | e询网 | CWEEK | 蜂鸟网 | GameSpot China | 个人电脑 | PChome | SPN | 网友世界 | ZDNet China | 中关村在线
CNET NETWORKS 美国: BNET | CNET.com | CNET Download.com | CNET News.com | CNET Reviews | CNET Shopper.com | GameSpot | MP3.com | mySimon | Release 1.0 | Search.com | TechRepublic | TV.com | Webshots | ZDNet
Copyright (c) 2006 CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
ZDNet 公司标识是 CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号