Getting UTC OFFSET OF a timezone

Posted on 2010-09-02
Last Modified: 2012-05-10
I need a way on a clients pc to query what that pc believes is the UTC offset of any timezone so I can add or subtract it from the UTC of their timezone to get the offset in hours from the particular timezone

example: running code on a pc in eastern timezone i need to get the UTC
i want to pass in the timezone for Mountain and then add or subtract that value form the eastern timezone to get teh number of hours diffence
Dim tzTimeZone As TimeZone = System.TimeZone.CurrentTimeZone
        Dim tsUTCoffset As Integer = tzTimeZone.GetUtcOffset(Now()).Hours

Open in new window

Question by:hainansyndrome
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 4
LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33591618
try this....
DateTime.Now will return the "current" time based on your time zone.

DateTime.ToUniversalTime will return GMT time.

You can subtract the two values to get the difference...

Dim now As DateTime = DateTime.Now
Dim nowGMT As DateTime = now.ToUniversalTime()
Dim diff As TimeSpan = now.Subtract(nowGMT)
Debug.WriteLine(diff, "diff")

Open in new window

LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33591692
You can also read this ...there is a good example ...

Author Comment

ID: 33591699
no i need to get the difference of 2 timezones

1 being the zone of the pc this code is running off of
and the other being a random zone
PeopleSoft Has Never Been Easier

PeopleSoft Adoption Made Smooth & Simple!

On-The-Job Training Is made Intuitive & Easy With WalkMe's On-Screen Guidance Tool.  Claim Your Free WalkMe Account Now

LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33591794
you can use for any other pc this:
Dim OtherPcOffset As TimeSpan TimeZoneInfo.Local.GetUtcOffset(DateTimeOffset.Now)
REad this article ...
about Converting DateTimeOffset Values

Author Comment

ID: 33595825
ok hmmmmmmmm maybe this makes more sense

we are pulling data from a webservice to a PC
this pc could be in any timeszone, I have no trouble getting the timezone information for that timezone

the data from the webservice is a date time, so it gets offset to that timezone

SInce DST changed a while back i cant hard code Central TIme Zones offset
I need to get Central Time's offset per that PC to then add or substract from that Timeezones so I know how many hours i need to add or subtract from my date time

perviously we were just adding 12 hours to the datetime but i want it right
LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33595961

Author Comment

ID: 33607890
i read it and the problem i come up with is that central time is not always GMT -6 it is sometimes -5
it all hangs on DST just need a function that can grab all the settings from the local machine
anything short of changing the timezone to get the settings
LVL 18

Accepted Solution

John (Yiannis) Toutountzoglou earned 500 total points
ID: 33608027
You can use a combination of all above...
You can always detect when daylight saving is applied on a client using this:
Dim t As TimeZone = System.TimeZone.CurrentTimeZone
Dim dls as boolean = t.IsDaylightSavingTime(Now)

PS: pc clock will auto update daylightsaving if needed

Also take a look here

Author Closing Comment

ID: 33718866
took some digging around

Featured Post

MS Dynamics Made Instantly Simpler

Make Your Microsoft Dynamics Investment Count  & Drastically Decrease Training Time by Providing Intuitive Step-By-Step WalkThru Tutorials.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction As chip makers focus on adding processor cores over increasing clock speed, developers need to utilize the features of modern CPUs.  One of the ways we can do this is by implementing parallel algorithms in our software.   One recent…
It’s quite interesting for me as I worked with Excel using for some time. Here are some topics which I know want to share with others whom this might help. First of all if you are working with Excel then you need to Download the Following …
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…

717 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question