Solved

Getting UTC OFFSET OF a timezone

Posted on 2010-09-02
9
498 Views
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

0
Comment
Question by:hainansyndrome
  • 5
  • 4
9 Comments
 
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

0
 
LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33591692
You can also read this ...there is a good example ...
http://msdn.microsoft.com/en-us/library/system.timezone.getutcoffset(VS.71).aspx
0
 

Author Comment

by:hainansyndrome
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
0
 
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 ...
http://msdn.microsoft.com/en-us/library/bb397769.aspx
about Converting DateTimeOffset Values
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 

Author Comment

by:hainansyndrome
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
0
 
LVL 18

Expert Comment

by:John (Yiannis) Toutountzoglou
ID: 33595961
0
 

Author Comment

by:hainansyndrome
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
0
 
LVL 18

Accepted Solution

by:
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
http://www.michaelbrumm.com/simpletimezone.html
0
 

Author Closing Comment

by:hainansyndrome
ID: 33718866
took some digging around
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Well, all of us have seen the multiple EXCEL.EXE's in task manager that won't die even if you call the .close, .dispose methods. Try this method to kill any excels in memory. You can copy the kill function to create a check function and replace the …
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
Many functions in Excel can make decisions. The most simple of these is the IF function: it returns a value depending on whether a condition you describe is true or false. Once you get the hang of using the IF function, you will find it easier to us…

867 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

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now