Python语言编写电脑时间自动同步小工具


Posted in Python onMarch 08, 2013

话不多说,小工具需求如下:
功能需求 -- 电脑开机后自动执行时间同步
非功能需求 -- 安装执行简单,无需安装额外环境

一、代码实现

基于以上需求,思路如下:访问网络获取北京时间,然后调用命令行来设置系统时间。程序写成Windows Service,并设置为开机自动运行。正好前段时间在学习Python,所以打算用Python来写这个工具。具体代码如下:

获取网络时间

 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

同步本地系统时间
 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])

二、部署安装

为了让Python程序能以Windows服务的方式运行,需要用到py2exe(用来把Python程序编译成exe)和Python Win32 Extensions 。(py2exe把Python代码编译成Winodws服务时依赖此组件)下载并安装这两个组件。安装完毕后,在Python的安装目录下找到py2exe的Windows Service示例({PythonRoot}\Lib\site-packages\py2exe\samples\advanced\MyService.py)。然后仿照这个示例将上面的代码完善一下。

Windows服务示例

 import win32serviceutil
 import win32service
 import win32event
 import win32evtlogutil class SynctimeService(win32serviceutil.ServiceFramework):
     _svc_name_ = "Synctime"
     _svc_display_name_ = "Synctime"
     _svc_description_ = "Synchronize local system time with beijin time"
    _svc_deps_ = ["EventLog"]
    def __init__(self, args):
        win32serviceutil.ServiceFramework.__init__(self, args)
        self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)

    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        win32event.SetEvent(self.hWaitStop)
    def SvcDoRun(self):
        import servicemanager
        # Write a 'started' event to the event log...
        win32evtlogutil.ReportEvent(self._svc_name_,
                                    servicemanager.PYS_SERVICE_STARTED,
                                    0, # category
                                    servicemanager.EVENTLOG_INFORMATION_TYPE,
                                    (self._svc_name_, ''))
        # wait for beeing stopped...
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)
        # and write a 'stopped' event to the event log.
        win32evtlogutil.ReportEvent(self._svc_name_,
                                    servicemanager.PYS_SERVICE_STOPPED,
                                    0, # category
                                    servicemanager.EVENTLOG_INFORMATION_TYPE,
                                    (self._svc_name_, ''))   
if __name__ == '__main__':
    # Note that this code will not be run in the 'frozen' exe-file!!!
    win32serviceutil.HandleCommandLine(SynctimeService) 

之后,再编写一个steup.py文件用来生成安装文件。

Setup.py

 from distutils.core import setup
 import py2exe setup(
     # The first three parameters are not required, if at least a
     # 'version' is given, then a versioninfo resource is built from
     # them and added to the executables.
     version = "0.0.1",
     description = "Synchroniz local system time with beijin time",
     name = "sysctime",
     # targets to build
     # console = ["synctime.py"],
     service=["synctime"]
 )

编译生成windows程序,如下图:

Python语言编写电脑时间自动同步小工具

然后在控制台中运行:setup.py py2exe ,一切顺利的话会在当前目录下生成build和dist目录。

Python语言编写电脑时间自动同步小工具

控制台目录切换到dist目录,找到synctime.exe,在命令行中运行:

synctime.exe ?install (-remove)  安装或移除时间同步服务。

现在可以运行services.msc查看服务运行情况Python语言编写电脑时间自动同步小工具

可以看到服务并没有启动,而且启动方式为手动。在这里可以右击服务选择属性手动把服务启动起来,并且设置为服务自动启动。

好吧,我承认。这样操作跟上面的需求有点出入了,略显麻烦。为了解决这个问题,自然想到的是用批处理来做。在dist目录下分别建两个批处理文件:

installservice.bat

 @echo off :: 安装windows服务
 echo 正在安装服务,请稍候...
 synctime.exe -install
 :: 设置服务自动启动
 echo 正在启动服务...
 sc config Synctime start= AUTO

:: 启动服务
sc start Synctime
echo 服务启动成功, 按任意键继续...
pause

removeserivce.bat

@echo off
:: 停止服务
echo 正在停止服务,请稍候...
sc stop Synctime
echo 正在卸载服务...
:: 删除windows服务
synctime.exe -remove
echo 服务卸载完成,请按任意键继续剩余卸载...
pause

好了,现在可以把dist打个包发给老妈用了。但是,这样发个一个压缩包,看起来也太不专业了。解决的办法是打一个安装包,把bat脚本打到安装包里,在安装程序时由安装包调用。这里我用的是NISI(使用HM VNISEdit打包向导来生成打包脚本非常方便)。

三、最终安装效果图

Python语言编写电脑时间自动同步小工具

Python语言编写电脑时间自动同步小工具

四、结尾

遗留的问题:

1、从上面的截图可以看到,安装程序在调用批处理时会显示出控制台窗口。这个问题我在网上查找资料,NSIS有相关的插件可以隐藏控制台窗口调用bat文件。
2、我源代码中有写日志文件的操作,但是以Windows服务的方式运行后,日志文件不能写了,不知道有没有好的解决办法。
3、360 ...真是要人命啊....Orz..

时间同步工具及源代码:https://3water.com/softs/74865.html

编译方法:

第一步: 安装Python环境(什么?还没有Python环境?... - -!)
第二步: 安装依赖组件
1、py2exe (目前只支持到python2.7)
2、Python Win32 Extensions

第三步(可选):安装Nsis环境,用来编译脚本

第四步:将synctime.py编译成windows程序
1、在当前目录下运行"setup.py py2exe",顺利的话会在当前目录下生成dist和build目录

第五步: 运行,有两种运行方式:
1、将installservice.bat 和 removeservice.bat 拷贝到dist中运行即可
2(依赖第三步)、使用Nsis编译Synctime.nsi脚本,生成安装包, 安装后运行(推荐)

Python 相关文章推荐
简述Python中的进程、线程、协程
Mar 18 Python
利用Python中的pandas库对cdn日志进行分析详解
Mar 07 Python
用 Python 爬了爬自己的微信朋友(实例讲解)
Aug 25 Python
python numpy元素的区间查找方法
Nov 14 Python
对python 中re.sub,replace(),strip()的区别详解
Jul 22 Python
python使用sklearn实现决策树的方法示例
Sep 12 Python
tensorflow指定GPU与动态分配GPU memory设置
Feb 03 Python
Python进程的通信Queue、Pipe实例分析
Mar 30 Python
python爬虫请求头设置代码
Jul 28 Python
Python3爬虫里关于代理的设置总结
Jul 30 Python
详解Python中的Lock和Rlock
Jan 26 Python
python 爬取豆瓣网页的示例
Apr 13 Python
py2exe 编译ico图标的代码
Mar 08 #Python
python中wx将图标显示在右下角的脚本代码
Mar 08 #Python
python中关于时间和日期函数的常用计算总结(time和datatime)
Mar 08 #Python
python中关于日期时间处理的问答集锦
Mar 08 #Python
python局部赋值的规则
Mar 07 #Python
Python 用户登录验证的小例子
Mar 06 #Python
Eclipse + Python 的安装与配置流程
Mar 05 #Python
You might like
php的sso单点登录实现方法
2015/01/08 PHP
在php中设置session用memcache来存储的方法总结
2016/01/14 PHP
IE Firefox 使用自定义标签的区别
2009/10/15 Javascript
为JavaScript添加重载函数的辅助方法
2010/07/04 Javascript
简单实用的js调试logger组件实现代码
2010/11/20 Javascript
Jquery 的扩展方法总结
2011/10/01 Javascript
Javascript 异步加载详解(浏览器在javascript的加载方式)
2012/05/20 Javascript
js操作CheckBoxList实现全选/反选(在客服端完成)
2013/02/02 Javascript
JS控制图片翻转示例代码(兼容firefox,ie,chrome)
2013/12/19 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
2014/12/15 Javascript
学习使用grunt来打包JavaScript和CSS程序的教程
2016/01/04 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
2016/05/17 Javascript
AngularJS ng-repeat数组有重复值的解决方法
2016/10/23 Javascript
JavaScript实现简易的天数计算器实例【附demo源码下载】
2017/01/18 Javascript
JS实现点击循环切换显示内容的方法
2017/10/19 Javascript
clipboard在vue中的使用的方法示例
2018/10/19 Javascript
微信小程序实现星星评价效果
2018/11/02 Javascript
WebSocket的简单介绍及应用
2019/05/23 Javascript
kafka调试中遇到Connection to node -1 could not be established. Broker may not be available.
2019/09/17 Javascript
Node.js API详解之 os模块用法实例分析
2020/05/06 Javascript
微信小程序实现canvas分享朋友圈海报
2020/06/21 Javascript
vue-cli 关闭热更新操作
2020/09/18 Javascript
Python实现的矩阵类实例
2017/08/22 Python
Python基于Flask框架配置依赖包信息的项目迁移部署
2018/03/02 Python
Python OpenCV处理图像之图像像素点操作
2018/07/10 Python
浅析Python3 pip换源问题
2020/01/06 Python
Keras实现支持masking的Flatten层代码
2020/06/16 Python
浅谈Python3中print函数的换行
2020/08/05 Python
python实现AdaBoost算法的示例
2020/10/03 Python
跑操口号
2014/06/12 职场文书
求职简历自荐信
2014/06/18 职场文书
小学生纪律委员竞选稿
2015/11/19 职场文书
2016年度优秀辅导员事迹材料
2016/02/26 职场文书
如何解决php-fpm启动不了问题
2021/11/17 PHP
Python数据结构之队列详解
2022/03/21 Python
Java 异步任务计算FutureTask
2022/04/28 Java/Android