欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python語言編寫電腦時間自動同步小工具

 更新時間:2013年03月08日 17:04:35   投稿:mdxy-dxy  
家里有臺很多年前買的電腦,CMOS電池殘廢了,經(jīng)常遇到開機后系統(tǒng)時間被重置的情況

話不多說,小工具需求如下:
功能需求 -- 電腦開機后自動執(zhí)行時間同步
非功能需求 -- 安裝執(zhí)行簡單,無需安裝額外環(huán)境

一、代碼實現(xiàn)

基于以上需求,思路如下:訪問網(wǎng)絡(luò)獲取北京時間,然后調(diào)用命令行來設(shè)置系統(tǒng)時間。程序?qū)懗蒞indows Service,并設(shè)置為開機自動運行。正好前段時間在學(xué)習(xí)Python,所以打算用Python來寫這個工具。具體代碼如下:

獲取網(wǎng)絡(luò)時間

復(fù)制代碼 代碼如下:

 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:
             #解析響應(yīng)的消息
             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

同步本地系統(tǒng)時間
復(fù)制代碼 代碼如下:

 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))     #設(shè)置日期
         os.system("time %d:%d:%d.0" % (tm_hour, tm_min, tm_sec))    #設(shè)置時間
         logging.info("syncLocalTime complete, current local time: %d-%d-%d %d:%d:%d \n" % time.localtime()[:6])

二、部署安裝

為了讓Python程序能以Windows服務(wù)的方式運行,需要用到py2exe(用來把Python程序編譯成exe)和Python Win32 Extensions 。(py2exe把Python代碼編譯成Winodws服務(wù)時依賴此組件)下載并安裝這兩個組件。安裝完畢后,在Python的安裝目錄下找到py2exe的Windows Service示例({PythonRoot}\Lib\site-packages\py2exe\samples\advanced\MyService.py)。然后仿照這個示例將上面的代碼完善一下。

Windows服務(wù)示例

復(fù)制代碼 代碼如下:

 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

復(fù)制代碼 代碼如下:

 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程序,如下圖:

然后在控制臺中運行:setup.py py2exe ,一切順利的話會在當前目錄下生成build和dist目錄。

控制臺目錄切換到dist目錄,找到synctime.exe,在命令行中運行:

synctime.exe –install (-remove)  安裝或移除時間同步服務(wù)。

現(xiàn)在可以運行services.msc查看服務(wù)運行情況

可以看到服務(wù)并沒有啟動,而且啟動方式為手動。在這里可以右擊服務(wù)選擇屬性手動把服務(wù)啟動起來,并且設(shè)置為服務(wù)自動啟動。

好吧,我承認。這樣操作跟上面的需求有點出入了,略顯麻煩。為了解決這個問題,自然想到的是用批處理來做。在dist目錄下分別建兩個批處理文件:

installservice.bat

復(fù)制代碼 代碼如下:

 @echo off
 
 :: 安裝windows服務(wù)
 echo 正在安裝服務(wù),請稍候...
 synctime.exe -install
 
 :: 設(shè)置服務(wù)自動啟動
 echo 正在啟動服務(wù)...
 sc config Synctime start= AUTO

:: 啟動服務(wù)
sc start Synctime

echo 服務(wù)啟動成功, 按任意鍵繼續(xù)...
pause



removeserivce.bat

復(fù)制代碼 代碼如下:

@echo off

:: 停止服務(wù)
echo 正在停止服務(wù),請稍候...
sc stop Synctime

echo 正在卸載服務(wù)...
:: 刪除windows服務(wù)
synctime.exe -remove

echo 服務(wù)卸載完成,請按任意鍵繼續(xù)剩余卸載...
pause

三、最終安裝效果圖

四、結(jié)尾

遺留的問題:

1、從上面的截圖可以看到,安裝程序在調(diào)用批處理時會顯示出控制臺窗口。這個問題我在網(wǎng)上查找資料,NSIS有相關(guān)的插件可以隱藏控制臺窗口調(diào)用bat文件。
2、我源代碼中有寫日志文件的操作,但是以Windows服務(wù)的方式運行后,日志文件不能寫了,不知道有沒有好的解決辦法。
3、360 ...真是要人命啊....Orz..

時間同步工具及源代碼://www.dbjr.com.cn/softs/74865.html

編譯方法:

第一步: 安裝Python環(huán)境(什么?還沒有Python環(huán)境?... - -!)
第二步: 安裝依賴組件
1、py2exe (目前只支持到python2.7)
2、Python Win32 Extensions

第三步(可選):安裝Nsis環(huán)境,用來編譯腳本

第四步:將synctime.py編譯成windows程序
1、在當前目錄下運行"setup.py py2exe",順利的話會在當前目錄下生成dist和build目錄

第五步: 運行,有兩種運行方式:
1、將installservice.bat 和 removeservice.bat 拷貝到dist中運行即可
2(依賴第三步)、使用Nsis編譯Synctime.nsi腳本,生成安裝包, 安裝后運行(推薦)

相關(guān)文章

  • Python讀取中文路徑出現(xiàn)亂碼的問題解決

    Python讀取中文路徑出現(xiàn)亂碼的問題解決

    本文主要介紹了Python讀取中文路徑出現(xiàn)亂碼的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • python 繪制正態(tài)曲線的示例

    python 繪制正態(tài)曲線的示例

    這篇文章主要介紹了python 繪制正態(tài)曲線的示例,幫助大家更好的利用python繪制圖像,感興趣的朋友可以了解下
    2020-09-09
  • python實現(xiàn)請求數(shù)據(jù)包簽名

    python實現(xiàn)請求數(shù)據(jù)包簽名

    這篇文章主要介紹了python實現(xiàn)請求數(shù)據(jù)包簽名,主要以python怎么快速對請求體做一次簽名為主題,塑造實現(xiàn)請求數(shù)據(jù)包簽名過程,具有一定得參考價值,需要的小伙伴可以參考一下
    2022-02-02
  • 實例解析Python的Twisted框架中Deferred對象的用法

    實例解析Python的Twisted框架中Deferred對象的用法

    Deferred對象在Twsited框架中用于處理回調(diào),這對于依靠異步的Twisted來說十分重要,接下來我們就以實例解析Python的Twisted框架中Deferred對象的用法
    2016-05-05
  • Python 中的 import 機制之實現(xiàn)遠程導(dǎo)入模塊

    Python 中的 import 機制之實現(xiàn)遠程導(dǎo)入模塊

    模塊導(dǎo)入( import ),是指在一個模塊中使用另一個模塊的代碼的操作,它有利于代碼的復(fù)用。這篇文章主要介紹了Python 的 import 機制:實現(xiàn)遠程導(dǎo)入模塊,需要的朋友可以參考下
    2019-10-10
  • Python?OpenCV實現(xiàn)人物動漫化效果

    Python?OpenCV實現(xiàn)人物動漫化效果

    這篇文章主要介紹了利用Python和OpenCV實現(xiàn)人物的動漫化特效,文中的示例代碼講解詳細,對我們學(xué)習(xí)Python和OpenCV有一定的幫助,需要的可以了解一下
    2022-01-01
  • 用python + openpyxl處理excel2007文檔思路以及心得

    用python + openpyxl處理excel2007文檔思路以及心得

    最近要幫做RA的老姐寫個合并excel工作表的腳本……源數(shù)據(jù)是4000+個excel 工作表,分布在9個xlsm文件里,文件內(nèi)容是中英文混雜的一些數(shù)據(jù),需要從每張表中提取需要的部分,分門別類合并到多個大的表里。
    2014-07-07
  • 解決Jupyter notebook中.py與.ipynb文件的import問題

    解決Jupyter notebook中.py與.ipynb文件的import問題

    這篇文章主要介紹了解決Jupyter notebook中.py與.ipynb文件的import問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 深入淺析python3 依賴倒置原則(示例代碼)

    深入淺析python3 依賴倒置原則(示例代碼)

    今天通過園區(qū)停車信息這樣一個場景分析python3 依賴倒置原則,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-07-07
  • python 實現(xiàn)繪制整齊的表格

    python 實現(xiàn)繪制整齊的表格

    今天小編就為大家分享一篇python 實現(xiàn)繪制整齊的表格,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11

最新評論