PermissionError при закрытии книги xlsxwriter в QPython, несмотря на наличие разрешений
У меня есть разрешение на запись в определенный каталог, и файл тоже создается. Но линия 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
>>>
РЕДАКТИРОВАТЬ: Решение
Если кто-то сталкивается с этой ошибкой на ПК, решение jmcnamara будет уместным.
w = xlsxwriter.Workbook('0.xlsx', {'tmpdir': 'path/to/tmpdir'})
Это не сработало с qpython. Так что я использовал in_memory
параметр конструктора, который работал.
w = xlsxwriter.Workbook('0.xlsx', {'in_memory': True})
1 ответ
XlsxWriter использует tmp-файлы для создания XML-файлов, которые составляют файл xlsx, прежде чем архивировать их в файл xlsx.
Ошибка, которую вы видите, связана с отсутствием прав доступа к каталогу tmp, который Python использует в вашей системе. Обратите внимание, что этот каталог не совпадает с каталогом, в котором создается выходной файл.
Вы можете найти местоположение tmpdir, запустив следующее в той же среде, что и ваше приложение:
import tempfile
print(tempfile.gettempdir())
Вы можете решить это двумя способами:
- Измените разрешение на использование tmp dir по умолчанию в Python и, следовательно, в XlsxWriter.
- Измените местоположение каталога tmp, используемого XlsxWriter, используя
tmpdir
параметр конструктора.