winnie.chan=Winnie Chan= tom.chow=Tom Chow= frankie.chow=Frankie Chow= 这档案的意义就是说当在数据中如果遇上 Frankie Chow 就把它转换成 frankie.chow ,另外当遇上 Peter wong 就把它转换成 peter.wong 。 另外有一文件名为 test.ldif ,读者可以先把它看成一个普通的文本文件。 dn: uid=Frankie Chow,ou=users,ou=samba,dc=godclick,dc=net uid: Frankie Chow sambaSID: S-1-5-21-2093837416-124xxxxxxxxxxxxxxxxxxxxxxxx70-1872 sambaPrimaryGroupSID: S-1-5-21-2093837416-124xxxxxxxxxxxxxxxxxxxxxxxxxxxxx70-513 displayName: Frankie Chow sambaLogonTime: 1079690765 sambaLogoffTime: 2147483647 sambaKicKOFfTime: 2147483647 sambaPwdCanChange: 0 sambaPwdMustChange: 2147483647 sambaLMPassWord: 29B9xxxxxxxxxGHTHC sambaNTPassword: 96B9xxxxxxxxxTHHDA sambaPwdLastSet: 1064457577 sambaAcctFlags: [UX ] objectClass: sambaSamAccount objectClass: account dn: uid=Tom Chan,ou=users,ou=samba,dc=godclick,dc=net uid: Tom Chan sambaSID: S-1-5-21-2093837416-124xxxxxxx70-1682 sambaPrimaryGroupSID: S-1-5-21-2093837416-124xxxxxx70-513 ... 现在把 test.ldif 中所遇见的任何串字倚 cuser.map 来转换。很多时初学 Perl 的学生就会先想把 cuser.map 打开,然后再打开 test.ldif ,然后比较转换。其实这种思考方式就是没有善用 perl 中的数据结构功能。 其实可以用以下的方式来重新思考这问题。可以先建立一数据结构 < arrayref/hashref >,然后把 cuser.map 内的各笔数据放入,那只需要使用一个简单的 foreach 就可以把 test.ldif 的数据来作转换了。 这是笔者的 perl script ------------------------------------------------------------------------ #!/usr/bin/perl -w sub cNameMap { # Create a Data StrUCture for storage cuser.map # $cname = [ # { # source => "Frankie Chow", # target => "frankie.chow" # }, # ... # ]; my $cname = []; open $datafile, " while (<$datafile>) { @usermapdata = split("=",$_); push (@$cname, { source => $usermapdata[1], target => $usermapdata[0] } ); }; return $cname ; } $cnamemap = &cNameMap ; CHANGEFILE: { open $sourcefile, "<test.ldif"; while ($line = <$sourcefile>) { foreach (@$cnamemap) { $line =~ s/$_->{source}/$_->{target}/; }; print $line; }; }; __END__
(出处:http://www.sheup.com)