1

我确实有权写入特定目录,并且文件也被创建。但是该行w.close()会导致错误。

因为我使用这个模块来创建文件,所以它没有在任何其他应用程序中打开。

如果它是相关的,其他模块就像csv工作正常。

/data/user/0/org.qpython.qpy/files/bin/qpython3-android5.sh && exit
n/qpython3-android5.sh && exit          <
Python 3.6.6 (qpyc:3.6.6, Jul 26 2018, 03:54:22) [BUILD WITH QPY3-TOOLCHAIN (https://github.com/qpython-android) ] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import os
>>> os.chdir('scripts3')
>>> os.getcwd()
'/storage/emulated/0/qpython/scripts3'
>>> import xlsxwriter
>>> w = xlsxwriter.Workbook('0.xlsx')
>>> w.close()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/data/user/0/org.qpython.qpy/files/lib/python3.6/site-packages/xlsxwriter/workbook.py", line 306, in close
    self._store_workbook()
  File "/data/user/0/org.qpython.qpy/files/lib/python3.6/site-packages/xlsxwriter/workbook.py", line 675, in _store_workbook
    os.utime(os_filename, (timestamp, timestamp))
PermissionError: [Errno 1] Operation not permitted
>>>

编辑:解决方案

如果有人在 PC 中遇到此错误,jmcnamara 的解决方案将是合适的。

w = xlsxwriter.Workbook('0.xlsx', {'tmpdir': 'path/to/tmpdir'})

这不适用于 qpython。所以我使用in_memory了构造函数的参数,它起作用了。

w = xlsxwriter.Workbook('0.xlsx', {'in_memory': True})
4

1 回答 1

1

XlsxWriter 使用 tmp 文件创建构成 xlsx 文件的 XML 文件,然后再将它们压缩到 xlsx 文件中。

您看到的错误是由于 Python 在您的系统上使用的 tmp 目录缺少权限。请注意,此目录与创建输出文件的目录不同。

您可以通过在与您的应用程序相同的环境中运行以下命令来找到 tmpdir 位置:

import tempfile
print(tempfile.gettempdir())

您可以通过 2 种方式解决此问题:

  1. 更改 Python 以及 XlsxWriter 使用的默认 tmp 目录的权限。
  2. tmpdir 使用构造函数的参数更改 XlsxWriter 使用的 tmp 目录的位置。
于 2018-11-09T09:14:52.120 回答