BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
supp
Pyrite | Level 9

Is it possible to determine the time zone given a US address? If anyone has done this would you be willing to share your code?

1 ACCEPTED SOLUTION

Accepted Solutions
ballardw
Super User

You may have the SASHELP.ZIPCODE data set. That has Timezone name for the 5 digit Zip code if you have that as part of your address. Or the same data set has most city and town names (not many cross time zones). If you do not have that set you can find it at https://support.sas.com/rnd/datavisualization/mapsonline/html/misc.html click on the Current under the Archive to get the link to the newest version. Follow the instructions to import into SAS. It is worth updating this set at least once per year.

 

Note that the ZIP value in the SASHELP.ZIPCODE data set is numeric. So comparisons may need to convert your value if a character zip.

 

One example:

data have;
   input zip ;
   format zip z5.;
datalines;
00501
31044
;

proc sql;
   create table want as
   select a.*, b.timezone
   from have as a
        left join
        sashelp.zipcode as b
        on a.zip=b.zip;
quit;

 

View solution in original post

1 REPLY 1
ballardw
Super User

You may have the SASHELP.ZIPCODE data set. That has Timezone name for the 5 digit Zip code if you have that as part of your address. Or the same data set has most city and town names (not many cross time zones). If you do not have that set you can find it at https://support.sas.com/rnd/datavisualization/mapsonline/html/misc.html click on the Current under the Archive to get the link to the newest version. Follow the instructions to import into SAS. It is worth updating this set at least once per year.

 

Note that the ZIP value in the SASHELP.ZIPCODE data set is numeric. So comparisons may need to convert your value if a character zip.

 

One example:

data have;
   input zip ;
   format zip z5.;
datalines;
00501
31044
;

proc sql;
   create table want as
   select a.*, b.timezone
   from have as a
        left join
        sashelp.zipcode as b
        on a.zip=b.zip;
quit;

 

sas-innovate-2026-white.png



April 27 – 30 | Gaylord Texan | Grapevine, Texas

Registration is open

Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.
Register now and lock in 2025 pricing—just $495!

Register now

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 1 reply
  • 1716 views
  • 1 like
  • 2 in conversation