• 技术文章 >常见问题 >Python常见问题

    python保存文件出错怎么解决?

    yangyang2020-06-02 15:13:31原创3835

    在普通保存文件出现下面的错误:

    file save failed

    encoding failed:

    'latin-1' codec can't encode characters in position 57-60:ordinal not in range(256)

    解决方法:

    在你的代码中添加一行,如下图所示:

    2、python在Windows系统使用下面的方法保存文件出错

    # -*- 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中保存文件没有问题,在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系统的文件名中不允许出现/ \ : * " < > | 这几个符号。

    解决方法:

    我们在Window系统中使用上述代码的时候,只需要将:(冒号)改成其他Windows系统支持的符号就可以了。

    更多Python知识请关注Python自学网

    专题推荐:python
    上一篇:python按位或有什么用? 下一篇:python比java简单吗?

    相关文章推荐

    • python如何检查列表元素是否为零• python2.7中怎么换行?• python安装request失败怎么办?

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网