Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

datetime

42 views
Skip to first unread message

Max

unread,
Sep 13, 2012, 11:19:32 AM9/13/12
to pytho...@python.org
How do I set the time in Python?

Also, is there any *direct* way to shift it?

Say, it's 09:00 now and Python makes it 11:30 *without* me having specified
"11:30" but only given Python the 2h30m interval.

Note that any "indirect" methods may need complicated ways to keep
track of the milliseconds lost while running them. It even took around one
second in some virtual machine guest systems. So I'm hoping Python happens to
have the magic needed to do the job for me.

Chris Angelico

unread,
Sep 13, 2012, 11:43:04 AM9/13/12
to pytho...@python.org
On Fri, Sep 14, 2012 at 1:19 AM, Max <rea...@hushmail.com> wrote:
> Say, it's 09:00 now and Python makes it 11:30 *without* me having specified
> "11:30" but only given Python the 2h30m interval.

Could you cheat and change the timezone offset? :D

ChrisA

Ian Kelly

unread,
Sep 13, 2012, 1:08:23 PM9/13/12
to Python
On Thu, Sep 13, 2012 at 9:19 AM, Max <rea...@hushmail.com> wrote:
> How do I set the time in Python?

On what platform? I don't know of any libraries for this, so it would
be a matter of making the necessary system calls (which is all that a
library would do anyway).

> Also, is there any *direct* way to shift it?

Only by changing the timezone setting. Any method of offsetting the
system clock itself is going to involve at some level reading the
current value, adding or subtracting, and then setting the new value.

> Note that any "indirect" methods may need complicated ways to keep
> track of the milliseconds lost while running them. It even took around one
> second in some virtual machine guest systems. So I'm hoping Python happens to
> have the magic needed to do the job for me.

If you're concerned about individual seconds, then you probably should
do this in a low-level language like C. Also, the clock is going to
drift naturally over time anyway. How are you going to keep it in
sync if not with ntp?

Terry Reedy

unread,
Sep 13, 2012, 2:07:34 PM9/13/12
to pytho...@python.org
On 9/13/2012 11:19 AM, Max wrote:
> How do I set the time in Python?

If you look up 'time' in the index of the current manual, it directs you
to the time module.

"time.clock_settime(clk_id, time)
Set the time of the specified clock clk_id.
Availability: Unix.
New in version 3.3."

You did not specify *which* time to set, but ...

"time.CLOCK_REALTIME
System-wide real-time clock. Setting this clock requires appropriate
privileges.
Availability: Unix.
New in version 3.3."

Chris already suggested an approach for changing your process's idea of
time. However, setting time.timezone seems to have no effect

> Also, is there any *direct* way to shift it?

If you mean time.clock_shift(clk_id, shift_seconds), no.

time.clock_settime(clk_id, time.clock_gettime(clk_id) + delta_seconds)

> Note that any "indirect" methods may need complicated ways to keep
> track of the milliseconds lost while running them.

Whay would a millisecond matter? System clocks are never synchronized to
official UTC time that closely without special hardware to receive time
broadcasts.

> It even took around one
> second in some virtual machine guest systems. So I'm hoping Python happens to
> have the magic needed to do the job for me.

The above should be well under a second.

--
Terry Jan Reedy

Message has been deleted

readmax

unread,
Sep 13, 2012, 3:06:23 PM9/13/12
to pytho...@python.org
Terry Reedy <tjreedy <at> udel.edu> writes:


> You did not specify *which* time to set, but ...

>
> If you mean time.clock_shift(clk_id, shift_seconds), no.
>
> time.clock_settime(clk_id, time.clock_gettime(clk_id) + delta_seconds)
>

I am talking about the system-wide clock on Debian.
What should I use as "clk_id"?

BTW, if by "version 3.3" you mean python 3, I am only using 2.x.



Terry Reedy

unread,
Sep 13, 2012, 7:28:35 PM9/13/12
to pytho...@python.org
On 9/13/2012 3:06 PM, readmax wrote:
> Terry Reedy <tjreedy <at> udel.edu> writes:
>
>
>> You did not specify *which* time to set, but ...
>
>>
>> If you mean time.clock_shift(clk_id, shift_seconds), no.
>>
>> time.clock_settime(clk_id, time.clock_gettime(clk_id) + delta_seconds)
>>
>
> I am talking about the system-wide clock on Debian.
> What should I use as "clk_id"?

Read the doc.

> BTW, if by "version 3.3" you mean python 3

x.y in the doc means pythonx.y

--
Terry Jan Reedy

Steven D'Aprano

unread,
Sep 13, 2012, 11:35:29 PM9/13/12
to
On Thu, 13 Sep 2012 15:19:32 +0000, Max wrote:

> How do I set the time in Python?

You don't. You ask the operating system to set the time. If you don't
have permission to change the time, which regular users shouldn't have
because it is a security threat, it will (rightly) fail. E.g.:

import os
os.system('date -s %s' % date_str)

In Python 3.3 there is a wrapper in the time module that allows you to
set the clock without an explicit system call. Again, you need permission
to set the clock, or it will fail.


> Also, is there any *direct* way to shift it?
>
> Say, it's 09:00 now and Python makes it 11:30 *without* me having
> specified "11:30" but only given Python the 2h30m interval.

Certainly. Just call:

time.sleep(2*60**2 + 30*60)

and when it returns, the clock will have shifted forward by 2h30m, just
like magic!

*wink*



> Note that any "indirect" methods may need complicated ways to keep track
> of the milliseconds lost while running them. It even took around one
> second in some virtual machine guest systems. So I'm hoping Python
> happens to have the magic needed to do the job for me.

No. Setting the clock is not the business of any user-space application.
It is the job of the operating system, which will do it the right way. At
most, the application can call the OS, directly or indirectly, but it has
no control over how many milliseconds are lost when you do so.

On Linux, Unix or Mac, that right way is to use NTP, which will keep your
computer's clock syncronised with a trusted external source. In a virtual
machine, the right way is to use NTP to syncronise the VM host's time,
and then tell the host to synchronise itself with the VM. On Windows,
well you'll have to ask a Windows expert.

If you want to bypass NTP and manage time yourself -- say, you want to
simulate "what happens when the clock strikes midnight?" without having
to wait for midnight -- then you probably don't need millisecond
precision. If you do need millisecond precision -- why??? -- *and* expect
to do it from a user-space application, you're going to have a bad time.



--
Steven
Message has been deleted
Message has been deleted
0 new messages