今天我们来看一下如何用python获取网络时间和本地时间,直接上代码吧,代码中都有注释。
python获取网络时间
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
获取网络时间
def
getBeijinTime():
"""
获取北京时间
"""
try
:
conn
=
httplib.HTTPConnection( "www.beijing-time.org" )
conn.request(
"GET"
,
"/time.asp"
)
response
=
conn.getresponse()
print
response.status, response.reason
if
response.status = = 200 :
#解析响应的消息
result
=
response.read()
logging.debug(result)
data
=
result.split( "\r\n" )
year
=
data[ 1 ][ len ( "nyear" ) + 1 : len (data[ 1 ]) - 1 ]
month
=
data[ 2 ][ len ( "nmonth" ) + 1 : len (data[ 2 ]) - 1 ]
day
=
data[ 3 ][ len ( "nday" ) + 1 : len (data[ 3 ]) - 1 ]
#wday = data[4][len("nwday")+1 : len(data[4])-1]
hrs
=
data[ 5 ][ len ( "nhrs" ) + 1 : len (data[ 5 ]) - 1 ]
minute
=
data[ 6 ][ len ( "nmin" ) + 1 : len (data[ 6 ]) - 1 ]
sec
=
data[ 7 ][ len ( "nsec" ) + 1 : len (data[ 7 ]) - 1 ]
beijinTimeStr
=
"%s/%s/%s %s:%s:%s" % (year, month, day, hrs, minute, sec)
beijinTime
=
time.strptime(beijinTimeStr, "%Y/%m/%d %X" )
return
beijinTime
except
:
logging.exception(
"getBeijinTime except"
)
return
None
|
python获取本地时间
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
同步本地系统时间
def
syncLocalTime():
"""
同步本地时间
"""
logging.info(
"current local time is: %d-%d-%d %d:%d:%d"
% time.localtime()[: 6 ])
beijinTime
=
getBeijinTime()
if
beijinTime is None :
logging.info(
"get beijinTime is None, will try again in 30 seconds..."
)
timer
=
threading.Timer( 30.0 , syncLocalTime)
timer.start();
else
:
logging.info(
"get beijinTime is: %d-%d-%d %d:%d:%d"
% beijinTime[: 6 ])
tm_year, tm_mon, tm_mday, tm_hour, tm_min, tm_sec
=
beijinTime[: 6 ]
import
os
os.system(
"date %d-%d-%d"
% (tm_year, tm_mon, tm_mday)) #设置日期
os.system(
"time %d:%d:%d.0"
% (tm_hour, tm_min, tm_sec)) #设置时间
logging.info(
"syncLocalTime complete, current local time: %d-%d-%d %d:%d:%d \n"
% time.localtime()[: 6 ])
|