Python之Windows系統中的文件保存錯誤


  在本文中,將記錄筆者今天遇到的一個Python問題,即:由於操作系統的不同,保存文件名會產生問題。
  我們以Mac系統和Windows系統為例,使用下面的Python腳本來保存一個Excel文件,代碼如下:

# -*- coding: utf-8 -*-
import xlwt, datetime

# 創建一個workbook 設置編碼
workbook = xlwt.Workbook(encoding = 'utf-8')
# 創建一個worksheet
worksheet = workbook.add_sheet('My Worksheet')

# 寫入excel
worksheet.write(0, 0, label = 'this is test')

# 保存
suffix= datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
workbook.save('./test_%s.xls' % suffix)

在Mac系統中運行上述代碼,會生成Excel文件,如下圖:
生成了Excel文件
打開其中一個文件,內容如下:
Excel中的內容
  但是同樣的代碼,我們放在Windows系統中運行,會出現這樣的錯誤:

Traceback (most recent call last):
  File "C:/Users/HP/PycharmProjects/Github_From_PyCharm/test_xlwt.py", line 14, in <module>
    workbook.save('./test_%s.xls' % suffix)
  File "C:\Users\HP\PycharmProjects\test\venv\lib\site-packages\xlwt\Workbook.py", line 710, in save
    doc.save(filename_or_stream, self.get_biff_data())
  File "C:\Users\HP\PycharmProjects\test\venv\lib\site-packages\xlwt\CompoundDoc.py", line 262, in save
    f = open(file_name_or_filelike_obj, 'w+b')
OSError: [Errno 22] Invalid argument: './test_2020-02-19 21:12:13.xls'

出現該錯誤的原因並不是我們使用xlwt模塊的方式有問題,而是不同系統之間的差異,Windows系統的文件名中不允許出現/ \ : * " < > | 這幾個符號
  因此,上述代碼會在Windows系統中報錯,而Mac系統不會。我們在Window系統中使用上述代碼的時候,只需要將:(冒號)改成其他Windows系統支持的符號就可以了。
  這是筆者在開發時候遇到的坑,特此記錄,以做總結。關於Mac系統與Windows系統方面的差異,我覺得寫個總結是很有必要的,留待下次分享。

本人的微信公眾號: Python之悟(微信號為:easy_web_scrape),歡迎大家關注~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM