After reading
japhy's
Code Smarter, I thought maybe
unpack might do this job more efficiently than a regex? Something like this maybe:
$record = "abcdefghk Year Sales: 0123456.01 peter x193v 20i39
+ ";
for (unpack "A9 A17 A10 A5 A6 A1 A*", $record) {
$i++;
print $_,"\n" if $i%2;
}
I don't really know if unpack would be more efficient or not, but it might show an increase in speed if there was a large record set.
And just to give an example of how you might start doing this with substr:
@format=(9, 17, 10, 5, 6, 1, 11);
print_record($record, @format);
sub print_record {
$record = shift;
@format = @_;
for (@format) {
$i++;
$value = substr($record, $pointer, $_);
$pointer += $_;
print "value: '$value'\n" if $i % 2;
}
}
This method means that you're liable to have spaces padding variable length data though. Not exactly difficult to get rid of, but not quite as neat.
I guess it would also be fairly easy to use whatever method you choose to deconstruct a format definition itself.
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.