回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我正在努力使我的程序可执行给我的FTC团队。一切正常,但当我尝试使用包含python docx的脚本时,它并没有完成全部工作。当我在PyCharm和终端上运行它时,它就起作用了。这是密码。我有Python。在</p>
<pre><code>from tkinter import *
import sys,math,random,datetime,os,time
import tkinter.messagebox
from tkinter import filedialog
from tkinter.filedialog import askopenfilename
from tkinter.messagebox import showerror
from time import gmtime, strftime
from docx import Document
from docx.shared import Inches
import xlsxwriter
export = "Excel"
job = "No Job"
current_time = strftime("%m-%d-%Y", gmtime())
root = Tk()
TextArea = Text(width=60,height=17,pady=0)
task = Entry(width=90)
task.insert(10, "Task:")
e1 = Entry()
e1.insert(10, "First Name")
e2 = Entry()
e2.insert(10, "Last Name")
TextArea.insert(END, "Reflection:")
title = ["Titan Tech ", "Caleb Fahlgren made this!", "Python is life!", "FIRST Robotics!","This program is over 200 lines of code!"]
title = (random.choice(title))
root.title(title)
root.geometry("680x600")
#Submit Button
#This definition writes to the excel file
def Submit():
submit = tkinter.messagebox.askquestion("Submit Entry", "Are you sure you want to submit?")
if submit == "yes":
current_time = strftime("%m-%d-%Y %H:%M", gmtime())
fullname = "%s %s" % (e1.get(), e2.get())
lastname = "%s" % (e2.get())
task1 = "%s" % (task.get())
alltext = TextArea.get("1.0",END)
workbook = xlsxwriter.Workbook('Titan Tech ' + (strftime("%m-%d-%Y", gmtime())) + '.xlsx')
worksheet = workbook.add_worksheet()
format_text = workbook.add_format()
format_text.set_text_wrap()
cell_format = workbook.add_format({'align': 'center','valign': 'vcenter','border': 1,'text_wrap': 1})
middle = workbook.add_format({'align':'center'})
worksheet.merge_range('A5:G20', "", cell_format)
worksheet.merge_range('A4:G4', "", cell_format)
bold = workbook.add_format({'bold': 1})
worksheet.write('A1', 'Name:',bold)
worksheet.write('A4', task1)
worksheet.write_string('B1',fullname, bold)
worksheet.merge_range('A2:B2', "", cell_format)
worksheet.merge_range('D2:E2', "", cell_format)
worksheet.write_string('A2',"Student Initials")
worksheet.write_string('C2',"_______",middle)
worksheet.write_string('D2',"Mentor Initials")
worksheet.write_string('F2',"_______",middle)
worksheet.write('E1', 'Date:',bold)
worksheet.write('F1',(strftime("%m-%d-%Y", gmtime())),bold)
worksheet.write_rich_string('A5',alltext ,cell_format)
userconfirm = tkinter.messagebox.showinfo("Save","Your entry has been saved to an " + export + " document!")
workbook.close()
def Reset():
python = sys.executable
os.execl(python, python, * sys.argv)
def keypress(event):
if event.keysym == 'Escape':
root.destroy()
def Quit():
quitask = tkinter.messagebox.askquestion("Quit", "Are you sure you want to quit?")
if quitask == "yes":
root.destroy()
firstname = Label(root, text="First Name",font=("Helvetica", 12),fg="green")
lastname = Label(root, text="Last Name",font=("Helvetica", 12),fg="green")
time = Label(root, text=current_time, font=("Helvetica", 12),fg="black")
ScrollBar = Scrollbar(root)
ScrollBar.config(command=TextArea.yview)
TextArea.config(yscrollcommand=ScrollBar.set)
ScrollBar.pack(side=RIGHT, fill=Y)
def cf():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 1")
def al():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 2")
def cm():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 3")
def np():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 4")
def cp():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 5")
def ns():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 6")
def ct():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 7")
def kt():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 8")
def mt():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 9")
def ek():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Sample")
e2.insert(10, "Name 10")
def n():
e1.delete(0, 'end')
e2.delete(0, 'end')
e1.insert(10, "Team")
e2.insert(10, "Name")
def other():
e1.delete(0, 'end')
e2.delete(0, 'end')
def TextFile():
current_time = strftime("%m-%d-%Y", gmtime())
fullname = "%s %s" % (e1.get(), e2.get())
lastname = "%s" % (e2.get())
task1 = "%s" % (task.get())
alltext = TextArea.get("1.0",END)
textfile1 = tkinter.messagebox.askquestion("Text File", "Are you sure you want to export as a text file?")
if textfile1 == "yes":
textfile = open('Titan Tech' + (strftime("%m-%d-%Y", gmtime())) + '.txt',"w")
textfile.write("Titan Tech | Team # 10385 ")
textfile.write("Name: " + fullname)
textfile.write(" " + "Date: " + current_time)
textfile.write('\n' + '\n' + task1)
textfile.write('\n' + '\n' + alltext)
textfile.close()
tkinter.messagebox.showinfo("Save", "You have exported to text file successfully. It is in the location of this program.")
def helpmenusave():
helpsaveconfirm = tkinter.messagebox.showinfo("Save", "This program exports the Excel, World, or text document to the location of this program!")
def userinterfacemenu():
helpuserinterface = tkinter.messagebox.showinfo("User Interface", "The Users tab is where you can click on your name to autofill the name text boxes. The Export tab is where you choose to export to a specific format.")
def Open():
textopen = tkinter.filedialog.askopenfile(mode='r', filetypes=[('Text Files', '*.txt'),('All Files', '*')])
if textopen != None:
txtopen = textopen.read()
TextArea.delete(1.0,END)
TextArea.insert(END,txtopen)
tkinter.messagebox.showinfo("Open", "Success!")
try:
txtopen.close()
except AttributeError:
print("Attribute Error")
menubar = Menu(root)
filemenu = Menu(menubar,tearoff = 0)
filemenu.add_command(label="New",command=Reset)
filemenu.add_command(label="Open",command=Open)
filemenu.add_command(label="Exit",command=Quit)
menubar.add_cascade(label="File",menu=filemenu)
#help menu
helpmenu = Menu(menubar,tearoff = 0)
helpmenu.add_command(label="None", command=n)
helpmenu.add_command(label="Sample Name 1", command=cf)
helpmenu.add_command(label="Sample Name 2", command=al)
helpmenu.add_command(label="Sample Name 3", command=cm)
helpmenu.add_command(label="Sample Name 4", command=np)
helpmenu.add_command(label="Sample Name 5",command=cp)
helpmenu.add_command(label="Sample Name 6",command=ns)
helpmenu.add_command(label="Sample Name 7",command=ct)
helpmenu.add_command(label="Sample Name 8",command=kt)
helpmenu.add_command(label="Sample Name 9",command=mt)
helpmenu.add_command(label="Sample Name 10", command=ek)
helpmenu.add_command(label="Other", command=other)
menubar.add_cascade(label="Users",menu=helpmenu)
</code></pre>
<p>这就是问题所在。它在Pycharm和terminal中都可以工作,但是当我用PyInstaller编译它时,它只执行wordsaveask=tkinter.messagebox.ask问题线下什么都没有。它应该创建Word文件,但没有。我也没有收到任何错误消息。在</p>
^{pr2}$