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中操作MySQL入门实例
Feb 08 Python
Python实现微信公众平台自定义菜单实例
Mar 20 Python
Python下的twisted框架入门指引
Apr 15 Python
Python查找文件中包含中文的行方法
Dec 19 Python
python3爬虫怎样构建请求header
Dec 23 Python
Python 3.6打包成EXE可执行程序的实现
Oct 18 Python
Pandas时间序列:重采样及频率转换方式
Dec 26 Python
Python 实现向word(docx)中输出
Feb 13 Python
Python监听剪切板实现方法代码实例
Nov 11 Python
python爬虫中抓取指数的实例讲解
Dec 01 Python
python pyhs2 的安装操作
Apr 07 Python
利用 Python 的 Pandas和 NumPy 库来清理数据
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
数字转英文
2006/12/06 PHP
《PHP边学边教》(02.Apache+PHP环境配置――下篇)
2006/12/13 PHP
PHP删除非空目录的函数代码小结
2013/02/28 PHP
PHP之生成GIF动画的实现方法
2013/06/07 PHP
PHP在不同页面间传递Json数据示例代码
2013/06/08 PHP
ThinkPHP2.x防范XSS跨站攻击的方法
2015/09/25 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
jquery构造器的实现代码小结
2011/05/16 Javascript
css结合js制作下拉菜单示例代码
2014/02/27 Javascript
瀑布流布局代码一例
2014/04/11 Javascript
JavaScript中的全局对象介绍
2015/01/01 Javascript
NodeJs基本语法和类型
2015/02/13 NodeJs
JS传播事件、取消事件默认行为、阻止事件传播详解
2017/08/14 Javascript
React组件refs的使用详解
2018/02/09 Javascript
一秒学会微信小程序制作table表格
2019/02/14 Javascript
vue实现跨域的方法分析
2019/05/21 Javascript
微信小程序自定义单项选择器样式
2019/07/25 Javascript
vuejs移动端实现div拖拽移动
2019/07/25 Javascript
vue element upload组件 file-list的动态绑定实现
2019/10/11 Javascript
vue移动端使用canvas签名的实现
2020/01/15 Javascript
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
2021/01/08 Vue.js
Python编程之属性和方法实例详解
2015/05/19 Python
解决Pandas to_json()中文乱码,转化为json数组的问题
2018/05/10 Python
python3.x提取中文的正则表达式示例代码
2019/07/23 Python
对Django url的几种使用方式详解
2019/08/06 Python
python线程的几种创建方式详解
2019/08/29 Python
windows 10 设定计划任务自动执行 python 脚本的方法
2019/09/11 Python
HTML5对手机页面长按会粘贴复制禁用的解决方法
2016/07/19 HTML / CSS
洲际酒店集团美国官网:IHG美国
2017/11/16 全球购物
Chemist Warehouse中文网:澳洲连锁大药房
2021/02/05 全球购物
出纳员岗位责任制
2014/02/11 职场文书
党员公开承诺书和承诺事项
2014/03/25 职场文书
新年主持词
2014/03/27 职场文书
小学国庆节活动方案策划书
2014/09/16 职场文书
Python如何识别银行卡卡号?
2021/06/10 Python