They're free, but use at your own risk
The scripts referenced here are used in the operation of this weather station, and may be freely copied and used to support your station. Please note that you use these scripts at your own risk. No warranty is expressed or implied. I accept no liability for any damages that may ensue from their use.
You will need to configure them for your own particular weather station website.
A RSS Feed is available to help keep you informed on updates to the scripts.
Many of these scripts are now available on GitHub at https://github.com/ktrue
A Version History is available -- check back from time to time to see if there are updates to scripts you have downloaded earlier.
Announcements of version updates and new scripts are made on
WXForum.net and
Weather-Watch forums
and saratogaWXPHP Twitter account as they become available.
Note: Twitter widget has been disabled 3-Jul-2023 since it no longer displays the recent update Tweets.
This page was updated
Wednesday, 14-Aug-2024 7:40 AM
Carterlake.org scripts with a few mods...
Tom at carterlake.org has done a great job generating and freely sharing his PHP scripts for other sites to use. I started my own journey with PHP programming by using his scripts (and Larry's at Anole Computer) as learning examples, and I can't thank them enough for their sharing! With Tom's permission (and some encouragement), I've set up this page to have links to the carterlake scripts that I've modified for various puposes. Most of the mods have to do with formatting for XHTML 1.0-Strict output (even when the source page was not).
advforecast.php (NOAA Forecast for all NWS areas)
Note: as of 12-Mar-2007, the Western Region website (www.wrh.noaa.gov) now offers the point-printable forecasts in the same format as the other regional websites, so this script now works for WRH, ERH, SRH and CRH websites.
Tom's advforecast.php script takes the point-printable forecast from NOAA for Western, Eastern, Southern and Central region NOAA websites, and converts to a set of icons/conditions/temperatures and text forecast for inclusion on your webpage. My mods add XHTML 1.0-Strict output and the ability to handle a redirection for county forecasts (offered by www.crh.noaa.gov) in case a point-printable forecast is not available. See these threads for the erh2crh version (http://www.wxforum.net/viewtopic.php?p=3768, and http://www.weather-watch.com/smf/index.php/topic,22504.0.html ) The latest version of this script also offers automatic failover to the Zone forecast if the point-printable forecast is not available. Set "$NOAAZone = 'ssZnnn';" in the code for your NOAA warning zone.
The script supports the ?force=1 parameter to reload the cache file, and also a ?force=2 to load the cache file from the backup County Zone forecast.
To use, you'll need an icon set uploaded in the /forecast/images directory on your website, and to set the $fileName variable inside the script to the URL for the point-printable forecast.
With V2.06 and up, the new parsing of the failover Zone forecast requires additional icons (available below) to be placed on your website.
In July, 2015, the NOAA-NWS updated the icon set and provided a new dual-image icon to display 6-hour conditions for the 12-hour forecast icon. This icon is dynamically generated by a DualImage.php script (available below in the UPDATES file). With the DualImage.php script and associated icon templates installed, the V4.00+ version of advforecast2.php will support dynamic generation of dual images when needed. The script will fall-back to showing just the first 6-hour image if the DualImage.php is not available, OR if the meteotriviglio animated GIF images are used.
In June, 2017, the NWS forecast.weather.gov website had planned a major renovation and would deprecate the use of /MapClick.php?lat={latitude}&lon={longitude} for finding the weather at your location. V5.00 of advforecast2.php now uses the new api.weather.gov JSON feeds to generate the icons/forecast text as the V4.x and prior scripts would have no longer worked via page-scraping.
That conversion by NWS is on indefinite hold so either version V4.0x or V5.0x will work on your site at this time.
Also new with the V5.x script is the number of icons available rose from 9 to 14 and the option to display the old-format 9 icons or the new format with two rows of (up-to) 8 icons is controlled by one switch variable ($showTwoIconRows in the script, or $SITE['showTwoIconRows'] in Settings.php).
On February 27, 2018, the NWS switched forecast.weather.gov to HTTPS only, so advforecast2.php V4.02 and earlier will not work as those versions supported only HTTP access. The advforecast2.php V4.03 was released to handle HTTPS access and should be the last release of the venerable page-scraper script. Please note that the Version 5.x script uses the beta api.weather.gov JSON feed and already used HTTPS only.
The V5.09 script is included in the Base-USA Saratoga template. For those not wanting to use the beta code, you can download the V4.05 script below and use with your template. Both V4.05 and V5.x versions will continue to have support while the api.weather.gov is still in beta test.
Note: to use either 4.0x or 5.0x version of the script, it is important to continue using the point-printable version of the URL for your location based on the current https://www.weather.gov/ website. Your links should resemble:
https://forecast.weather.gov/MapClick.php?lat=nn.nnnn&lon=-nnn.nnnn&unit=0&lg=english&FcstType=text&TextType=2
with the &unit=0&lg=english&FcstType=text&TextType=2 at the end after the lat= and lon= arguments.
Tip: use NWS-info-map to quickly locate your desired forecast points and get copycode to put in the $NWSforecasts array.
Sample code
Sample included with:
<?php
$doIncludeNWS = true;
include("advforecast2.php");
?>
will show
National Weather Service Forecast for:
Saratoga, CA
Issued by: National Weather Service San Francisco Bay Area/Monterey, CA |
Updated: Fri, 04-Oct-2024 1:26am PDT |
|
Saratoga
|
Today
Sunny
|
Saturday
Sunny
|
Sunday
Sunny
|
Monday
Sunny
|
Tuesday
Sunny
|
Wednesday
Mostly Sunny
|
Thursday
Mostly Sunny
|
|
Hi 96 °F |
Hi 99 °F |
Hi 97 °F |
Hi 92 °F |
Hi 85 °F |
Hi 82 °F |
Hi 79 °F |
|
|
Tonight
Mostly Clear
|
Saturday Night
Mostly Clear
|
Sunday Night
Mostly Clear
|
Monday Night
Mostly Clear
|
Tuesday Night
Mostly Clear
|
Wednesday Night
Partly Cloudy
|
Thursday Night
Partly Cloudy then Slight Chance Drizzle
|
|
Lo 67 °F |
Lo 67 °F |
Lo 64 °F |
Lo 58 °F |
Lo 56 °F |
Lo 55 °F |
Lo 54 °F |
|
|
Excessive Heat Warning
Today
|
Sunny. High near 96, with temperatures falling to around 92 in the afternoon. North wind 1 to 6 mph. |
Tonight
|
Mostly clear, with a low around 67. Northwest wind around 5 mph. |
Saturday
|
Sunny. High near 99, with temperatures falling to around 97 in the afternoon. Northwest wind 2 to 6 mph. |
Saturday Night
|
Mostly clear, with a low around 67. North northeast wind 1 to 5 mph. |
Sunday
|
Sunny, with a high near 97. North wind 2 to 7 mph. |
Sunday Night
|
Mostly clear, with a low around 64. |
Monday
|
Sunny, with a high near 92. |
Monday Night
|
Mostly clear, with a low around 58. |
Tuesday
|
Sunny, with a high near 85. |
Tuesday Night
|
Mostly clear, with a low around 56. |
Wednesday
|
Mostly sunny, with a high near 82. |
Wednesday Night
|
Partly cloudy, with a low around 55. |
Thursday
|
Mostly sunny, with a high near 79. |
Thursday Night
|
A slight chance of drizzle after 5am. Partly cloudy, with a low around 54. |
Forecast from NOAA-NWS
for Saratoga, CA.
You can also include it 'silently' and print just a few (or all) the contents where you'd like it on the page
<?php
$doPrintNWS = false;
require("advforecast2.php"); ?>
then on your page, the following code would display just the current and next time period forecast:
<table>
<tr align="center" valign="top">
<?php print "<td>$forecasticons[0]</td><td>$forecasticons[1]</td>\n"; ?>
</tr>
<tr align="center" valign="top">
<?php print "<td>$forecasttemp[0]</td><td>$forecasttemp[1]</td>\n"; ?>
</tr>
</table>
Today
Sunny
| Tonight
Mostly Clear
|
Hi 96 °F | Lo 67 °F |
Or if you'd like to include the immediate forecast with text for the next two cycles:
<table>
<tr valign="top">
<?php print "<td align=\"center\">$forecasticons[0]<br />$forecasttemp[0]</td>\n"; ?>
<?php print "<td align=\"left\" valign=\"middle\">$forecasttext[0]</td>\n"; ?>
</tr>
<tr valign="top">
<?php print "<td align=\"center\">$forecasticons[1]<br />$forecasttemp[1]</td>\n"; ?>
<?php print "<td align=\"left\" valign=\"middle\">$forecasttext[1]</td>\n"; ?>
</tr>
</table>
Today
Sunny
Hi 96 °F |
Sunny. High near 96, with temperatures falling to around 92 in the afternoon. North wind 1 to 6 mph. |
Tonight
Mostly Clear
Lo 67 °F |
Mostly clear, with a low around 67. Northwest wind around 5 mph. |
Download: advforecast2.php (V5.19 - 27-Dec-2022) JSON version uses the api.weather.gov site, also included in the USA template.
Download: advforecast2.php (V4.06 -30-Apr-2024) older version for those not wanting to experiment with the api.weather.gov beta site
Download: Icon Set (V2 for NWS 55x55 icons)
(upload to your website in the /forecast/images directory)
Download: Icon Set UPDATES July-2015 and DualImage.php script
Download: Icon Set UPDATES April-2017 and DualImage.php script(upload to your website and preserve the directory names - included with Base-USA template)
Download: DualImage.php (V1.04 - 06-Apr-2022) - included with Base-USA template and icon sets above.