python中的系统中断_Python之Windows系统中的文件保存错误

在本文中,将记录笔者今天遇到的一个Python问题,即: 由于操作系统的不同,保存文件名会产生问题。 我们以Mac系统和Windows系统为例,使用下面的Python脚本来保存一个Excel文件,代码如下:
# -*- coding: utf-8 -*-import xlwt, datetime# 创建一个workbook 设置编码workbook = xlwt.Workbook(encoding = 'utf-8')# 创建一个worksheetworksheet = workbook.add_sheet('My Worksheet')# 写入excelworksheet.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文件,如下图:
041a2680e83c9f9fc3e274e89c3bb735.png 生成了Excel文件
打开其中一个文件,内容如下:
d23c5ba945c97e481280cfe5f5f355a0.png Excel中的内容
但是同样的代码,我们放在Windows系统中运行,会出现这样的错误:
Traceback (most recent call last):  File "C:/Users/HP/PycharmProjects/Github_From_PyCharm/test_xlwt.py", line 14, in     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系统支持的符号就可以了。

-END-

假期无法出门
不如在家学习

ee836dfe5521ef544dd14588f0aaa1bd.png

世界正在奖励坚持学习的人!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值