zoukankan      html  css  js  c++  java
  • 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:UsersHPPycharmProjects	estvenvlibsite-packagesxlwtWorkbook.py", line 710, in save
        doc.save(filename_or_stream, self.get_biff_data())
      File "C:UsersHPPycharmProjects	estvenvlibsite-packagesxlwtCompoundDoc.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),欢迎大家关注~

  • 相关阅读:
    python链家网高并发异步爬虫and异步存入数据
    python爬取百度文库所有内容
    PyQt5+requests实现车票查询工具
    python黑科技库:FuckIt.py,让你代码从此远离bug
    教你如何使用Python写游戏辅助脚本
    python实现定时发送qq消息
    Python利用带权重随机数解决抽奖和游戏爆装备问题
    Beta冲刺随笔集合
    用户调查报告
    Beta冲刺总结
  • 原文地址:https://www.cnblogs.com/jclian91/p/12333282.html
Copyright © 2011-2022 走看看