以下代码有效,但是当我打开CSV文件时它没有 按字母顺序或任何特定列出现。
我希望name
出现在第1列和grade
显示在旁边的第2列中。我不得不把它放进去
Tkinter并发现令我感到沮丧的是我无法对其进行排序。
我是新手,对任何建议都很感激。
from tkinter import *
import csv
class App(Frame):
def __init__(self, master=None):
Frame.__init__(self, master)
self.pack()
self.output()
#output
def output(self):
Heading=StringVar()
Heading.set("Please enter student name below")
Label(text='Name:').pack(side=LEFT,padx=5,pady=5)
self.n = Entry(root, width=10)
self.n.pack(side=LEFT,padx=5,pady=5)
#Text label
Label(text='Grade:').pack(side=LEFT,padx=5,pady=5)
self.e = Entry(root, width=10)
self.e.pack(side=LEFT,padx=6,pady=6)
self.b = Button(root, text='Submit', command=self.writeToFile)
self.b.pack(side=RIGHT,padx=5,pady=5)
self.b = Button(root, text='Clear', command=self.writeToFile)
self.b.pack(side=RIGHT,padx=5,pady=5)
#write to grade csv
def writeToFile(self):
with open('Grades.csv', 'a') as f:
w=csv.writer(f, quoting=csv.QUOTE_ALL)
w.writerow([self.n.get()])
w.writerow([self.e.get()])
#I think it is here I need to add in some code to write the data to a certain row or column in my CSV file.
if __name__ == "__main__":
root=Tk()
root.title('grade')
root.geometry('380x280')
app=App(master=root)
app.mainloop()
root.mainloop()
答案 0 :(得分:0)
为了在单独的列中写下每个名称和成绩,请执行以下操作:
<强>切换强>
w.writerow([self.n.get()])
w.writerow([self.e.get()])
:用于强>
w.writerow([self.n.get(), self.e.get()])
关于如何按字母顺序对csv文件进行排序已有一个问题,其中有3个答案可能会对您有所帮助: