I am trying to print out the records in a flatfile database,
with the results in alphabetical order, based on the first
8 characters in the first field, which is lname (last name).
This is what I have so far (doesnt work).
sub view_it {
open (DATABASE, "$mydata") || &CgiDie ("I am sorry, but I was not able
+ to open the
data file.");
flock (DATABASE, 2);
@list = <DATABASE>;
flock (DATABASE, 8);
close (DATABASE);
foreach $list (@list) {
($lname, $fname, $email, $phone, $message, $ip, $date) = split(/\|\|/,
+ $list);
&byName;
$test = 1;
&print_it;
}
}
sub byName { # sort database by first 8 of last name
((substr $a, 0, 8) cmp (substr $b, 0, 8)); }
$i = 0; # loop counter
while (<>) { $filerecs[$i++] = $_; }
@sorted_recs = sort byName @filerecs
then it goes on to substitute the $lname for %%name%% etc,
and print it to a html template (which works fine).
Problem is, the script prints in reverse entry order
instead of alphabetical. Any suggestions for a
new kid that is really lost. ?
Shay
Edit kudra,
2001-10-30
Changed title
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.