gpt4 book ai didi

Python 错误 : xlsxwriter. exceptions.FileCreateError: [Errno 2] No such file or directory: ''

转载 作者:行者123 更新时间:2023-12-04 01:32:35 37 4
gpt4 key购买 nike

我想做什么:

我正在尝试使用文件对话框保存文件。保存部分运行良好,但如果我在选择不保存的对话框中单击取消,则会出现此错误。如何消除此错误?

我得到的错误:

Exception in Tkinter callback

FileNotFoundError: [Errno 2] No such file or directory: ''

During handling of the above exception, another exception occurred:


xlsxwriter.exceptions.FileCreateError: [Errno 2] No such file or directory: ''

下面是我的代码:

import xlsxwriter
import tkinter as tk
import tkinter.ttk as ttk
from tkinter import filedialog

def save():
filename = filedialog.asksaveasfilename(filetypes=[("Excel files", ".xlsx .xls")],defaultextension='.xlsx')
workbook = xlsxwriter.Workbook(filename)
worksheet = workbook.add_worksheet()
worksheet.write('A1', 'Common Information')
worksheet.write('A2', 'Circumference of Tank')
worksheet.write('C2', 'Height of Tank')
worksheet.write('A3', 'Minimum Thickness of Tank')
worksheet.write('C3', 'Maximum Thickness of Tank')

workbook.close()

window = tk.Tk()
window.configure(background='white')

ws = window.winfo_screenwidth()
hs = window.winfo_screenheight()
w = 700 # width for the Tk root
h = 585 # height for the Tk root
x = (ws / 2) - (w / 2)
y = (hs / 2) - (h / 2)

window.geometry('%dx%d+%d+%d' % (w, h, x, y))

canvas = tk.Canvas(window,bg="white",width=700, height=585, highlightthickness=0)
canvas.pack()


save1 = ttk.Button(canvas, text='Save', command= lambda: save())
canvas.create_window(15, 15, window=save1, anchor=tk.NW)


window.resizable(False, False)
window.mainloop()

最佳答案

您的保存函数将在您按下按钮后调用。

filename = filedialog.asksaveasfilename(filetypes=[("Excel files", ".xlsx .xls")],defaultextension='.xlsx')
....

因为当你停止选择路径时,文件名将是 (它是一个 str 类型但它的长度 == 0 )。并且 workbook = xlsxwriter .Workbook(filename) 将引发异常。

因此,在保存 xlsx 文件之前,您应该使用 if 语句。

save() 函数应该是:

def save():
filename = filedialog.asksaveasfilename(filetypes=[("Excel files", ".xlsx .xls")],defaultextension='.xlsx')
if filename:
workbook = xlsxwriter.Workbook(filename)
worksheet = workbook.add_worksheet()
worksheet.write('A1', 'Common Information')
worksheet.write('A2', 'Circumference of Tank')
worksheet.write('C2', 'Height of Tank')
worksheet.write('A3', 'Minimum Thickness of Tank')
worksheet.write('C3', 'Maximum Thickness of Tank')

workbook.close()

关于Python 错误 : xlsxwriter. exceptions.FileCreateError: [Errno 2] No such file or directory: '',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60654755/

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com