跳到主要內容

[Python] 將運作過程的debug message紀錄到log file的功能

軟體在運作過程難免會遇到一些非預期的狀況讓程式掛點或是種種的不正常行為,這時候往往案發現場不能保留,很多的線索都在重新啟動軟體後消失了。若軟體的行為是要與其他軟體進行交互的,那就更難找出問題了。

所以把軟體運作過程中重要的階段記錄下來是很重要的事,一方面自己軟體的bug可以很快找到觸發的點,另一方面若是別人的軟體造成我們的軟體掛點,log也可以幫助我們提出證據來澄清,不讓別人冤枉我們。

1. 新增一個save log的function:
    def saveLog(self, data):
        currentDirectory = os.getcwd()
        print(currentDirectory)
        filePath = '%s\\Log.txt' % (currentDirectory)
        try:
            if os.path.exists(filePath):
                fileSize = os.path.getsize(filePath)
                print(fileSize)
                if fileSize > 50000000:#50MB
                    os.remove(filePath)
            else:
                print('Log file does not exists')
        except:
            print("Error while deleting Log file ", filePath)
            return

        try:
            file = open(filePath, 'a+')
            file.write('%s\n' % (data))
            file.close()
        except IOError:
            print('Delete Log error!!')
2. 在你要記錄log的地方加上如下的句子:
saveFstLog('%s : %s' % (time.strftime("%Y%m%d%H%M%S", time.localtime()),data))
如此就能將"現在時間"與字串"data"的內容寫入當前目錄下的Log.txt檔案,並且檔案大小如果超過50MB會自動重新記錄。

留言

這個網誌中的熱門文章

[Python] 以.py檔案產生Windows EXE 執行檔

如何開發能在Windows下執行的Python程式?你當然可以在Windows下安裝Python之後用command line運行你的 .py source code來直接執行程式,但是這方法基本上只適合開發中的程式,或是自己寫好玩只在自己的PC上執行的程式,也許適用。 但若你的需求是要在每個Windows的OS下都可以執行、且是不公開程式碼的,那就必須要將你的 .py source code包裝成EXE執行檔了,下面就介紹如何進行: –下載 auto-py-to-exe-master https://github.com/brentvollebregt/auto-py-to-exe 1. 解壓縮auto-py-to-exe-master.zip到想要的路徑下(路徑不能有空格或".") 2. 開啟Cmd console 到auto-py-to-exe-master路徑下 3. 在console下執行"pip install -r requirements.txt" 4. 在console下執行"python run.py" 運行完畢後就可以選取你要轉成執行檔的 .py 檔案,進行製作。 可參考下面的影片: 產生出來的檔案包含執行檔與其程式中會用到的相關Lib檔案,所以要將整個output資料夾中的檔案一併提取出來 (不要只拿執行檔出來)。 如此你就可以在任意的Windows上執行你的程式了。

Visual Studio 軟體開發的授權問題

使用Visual Studio開發各種軟體產品非常的方便,此款地表最強軟體開發工具涵蓋了各種的程式語言。但在授權上需要注意一下,否則很有可能會被微軟收取罰金。         Visual Studio Community可以在任何狀況下使用,但是要商業用途(賣產品)只限個人創作,公司組織的話除非是開放原碼、教育、學術研究,除此之外皆不可使用。 因此公司組織要用Visual Studio做產品的話,一種做法是買一套Professional版本,開發時用 Community 版本,要Release給客戶時用 Professional 或更高級的版本編譯;另一種做法是不考慮轉用更高級版本,那麼一開始就採用 Express 版可以降低未來轉換之困擾。 但需要知道 Express 版少了許多功能(例如 Code Coverage、Profiling ...),並且從2019開始微軟不再推出Express版本,也意味著沒有"公司組織免費使用Visual Studio開發產品"的選項了。 微軟雖然不再推出Express版本,但有另一個免費的IDE工具VS code,也可用來開發軟體,只是相對來說Visual Studio只稱得上是一個程式編輯器,如果要在VS code上開發如Winform的程式,就要使用第三方的工具了,以下提供幾個VS code上開發的連結: VS code上開發Winform https://ironmansoftware.com/building-a-windows-form-app-with-powershell-in-vs-code/ VS code上開發ASP.NET core https://blog.johnwu.cc/article/asp-net-core-3-starting.html

[PyAutoGUI] 用程式控制鍵盤滑鼠的動作

想透過程式指令控制鍵盤滑鼠的行為,在Windows下一般可以透過VBScript,但是VBScript較適合針對鍵盤事件,至於滑鼠行為的控制在VBScript中沒有提供原生的控制功能,必須透過第三方提供的API進行實現。通常使用Windows Excel提供的API來完成,但Excel在不同的版本下有不同的差異,在不同的Windows 版本下又有不同相容性問題。 因此建議用Python提供的 PyAutoGUI 實作,前提是需要安裝Python和PyAutoGUI套件。 PS. 透過auto-py-to-exe-master將python source code編譯成執行檔(.exe)即可在任何Windows環境下執行而不用擔心相容性問題了。 參考連結: PyAutoGUI : 使用Python控制電腦