1999-01-17 11:18:52 -06:00
|
|
|
#!/usr/bin/perl -w
|
1999-01-02 00:39:00 -06:00
|
|
|
#
|
|
|
|
# example script showing how to use the Quote perl module.
|
1999-01-02 03:31:19 -06:00
|
|
|
# gets prices for some stocks, for some mutual funds
|
1999-01-02 00:39:00 -06:00
|
|
|
|
2000-08-19 14:45:41 -05:00
|
|
|
use Finance::Quote;
|
|
|
|
|
|
|
|
# Create a quote object.
|
|
|
|
my $quoter = Finance::Quote->new();
|
1999-01-02 00:39:00 -06:00
|
|
|
|
|
|
|
# -----------------------------------
|
|
|
|
# get quotes for two stocks ...
|
2000-08-19 14:45:41 -05:00
|
|
|
%quotes = $quoter->fetch("yahoo","IBM", "SGI");
|
1999-01-02 00:39:00 -06:00
|
|
|
|
|
|
|
# print some selected values
|
|
|
|
print "NYSE by Yahoo: ", $quotes {"IBM", "name"},
|
|
|
|
" last price: ", $quotes {"IBM", "last"}, "\n";
|
|
|
|
print "NYSE by Yahoo: ", $quotes {"SGI", "name"},
|
|
|
|
" last price: ", $quotes {"SGI", "last"}, "\n";
|
|
|
|
|
|
|
|
# loop over and print all values.
|
|
|
|
# Notes that values are stored ion a multi-dimensional associative array
|
|
|
|
foreach $k (sort (keys %quotes)) {
|
|
|
|
($sym, $attr) = split ($;, $k, 2);
|
|
|
|
$val = $quotes {$sym, $attr};
|
|
|
|
# $val = $quotes {$k}; # this also works, if desired ...
|
|
|
|
print "\t$sym $attr =\t $val\n";
|
|
|
|
}
|
|
|
|
print "\n\n";
|
|
|
|
|
|
|
|
# -----------------------------------
|
|
|
|
# get quotes from Fidelity Investments
|
|
|
|
@funds = ("FGRIX", "FNMIX", "FASGX", "FCONX");
|
2000-08-19 14:45:41 -05:00
|
|
|
%quotes = $quoter->fetch("fidelity",@funds);
|
1999-01-02 00:39:00 -06:00
|
|
|
|
|
|
|
foreach $f (@funds) {
|
|
|
|
$name = $quotes {$f, "name"};
|
|
|
|
$nav = $quotes {$f, "nav"};
|
|
|
|
print "Fidelity Fund $f $name \tNAV = $nav\n";
|
|
|
|
}
|
|
|
|
print "\n\n";
|
|
|
|
|
|
|
|
# -----------------------------------
|
|
|
|
@funds = ("FGRXX");
|
2000-08-19 14:45:41 -05:00
|
|
|
%quotes = $quoter->fetch("fidelity",@funds);
|
1999-01-02 00:39:00 -06:00
|
|
|
|
|
|
|
print "Not all funds have a NAV; some have Yeilds:\n";
|
|
|
|
foreach $f (@funds) {
|
|
|
|
$name = $quotes {$f, "name"};
|
|
|
|
$yield = $quotes {$f, "yield"};
|
|
|
|
print "\tFidelity $f $name 30-day Yield = $yield percent\n";
|
|
|
|
}
|
|
|
|
print "\n\n";
|
|
|
|
|
|
|
|
# -----------------------------------
|
|
|
|
# demo T. Rowe Price -- same as above
|
|
|
|
@funds = ("PRFDX", "PRIDX");
|
2000-08-19 14:45:41 -05:00
|
|
|
%quotes = $quoter->fetch("troweprice",@funds);
|
1999-01-02 00:39:00 -06:00
|
|
|
|
|
|
|
foreach $f (@funds) {
|
|
|
|
$nav = $quotes {$f, "nav"};
|
|
|
|
$dayte = $quotes {$f, "date"};
|
|
|
|
print "T. Rowe Price $f NAV = $nav as of $dayte\n";
|
|
|
|
}
|
|
|
|
print "\n\n";
|
|
|
|
|
|
|
|
|
|
|
|
# -----------------------------------
|
2000-03-29 18:49:54 -06:00
|
|
|
|
|
|
|
# demo for ASX. Grab the price of Coles-Myer and Telstra
|
|
|
|
@funds = ("CML","TLS");
|
2000-08-19 14:45:41 -05:00
|
|
|
%quotes = $quoter->fetch("australia",@funds);
|
2000-03-29 18:49:54 -06:00
|
|
|
foreach $f (@funds) {
|
|
|
|
print "ASX Price of $f is ".$quotes{$f,"last"}." at ".
|
|
|
|
$quotes{$f,"date"}."\n";
|
|
|
|
}
|
|
|
|
print "\n\n";
|