我正在嘗試創建 CSV 生成器,該生成器將為我將提供給他的用戶串列生成 csv 檔案。生成的行應該是這樣的:
add;[email protected];Rolename1
add;[email protected];Rolename2
add;[email protected];Rolename1
add;[email protected];Rolename2
這是如果我選擇角色 1 和 2 的復選框,它將為用戶添加具有兩個角色的行。到目前為止,我必須生成檔案,但我現在的主要問題是我不知道如何讓它從 tkinter Text 讀取用戶,然后將其保存到 csv 中。我希望它只接受 AZ 和 0-9 作為用戶名。到目前為止,這是我的代碼:
from tkinter import *
from tkinter import ttk
import datetime
import pandas as pd
root = Tk()
root.geometry('500x500')
root.title("Csv generator")
#Creator name
creator = Entry(root, width=23)
creator.grid(column=1,row=0)
creator.insert(0, "Enter here your username")
#Functions entry
functionLabel = Label(root, text="FUNCTION", width=10).grid(column=0, row=1, padx=10)
clickFunction = StringVar()
clickFunction.set("Select your function")
Function = OptionMenu(root, clickFunction, "add", "chg", "cho", "del")
Function.grid(column=0, row=2, padx=10)
#Username list
usernameLabel = Label(root, text="USERNAME",width=10)
usernameLabel.grid(column=1, row=1, padx=10)
usernameList = Text(root, width=10, height=4)
usernameList.grid(column=1, row=1, padx=10, rowspan=4)
#Role List
rolesLabel = Label(root, text="ROLES", width=10)
rolesLabel.grid(column=2, row=1, padx=10)
rolesCheck1 = StringVar()
role1 = Checkbutton(root, text="Role01", variable=rolesCheck1, onvalue="Role01", offvalue="")
role1.grid(column=2, row=2, padx=10)
rolesCheck2 = StringVar()
role2 = Checkbutton(root, text="Role02", variable=rolesCheck2)
role2.grid(column=2, row=3, padx=10)
rolesCheck3 = StringVar()
role3 = Checkbutton(root, text="Role1", variable=rolesCheck3)
role3.grid(column=2, row=4, padx=10)
rolesCheck4 = StringVar()
role4 = Checkbutton(root, text="Role2", variable=rolesCheck4)
role4.grid(column=2, row=5, padx=10)
#Read Textbox
def usersout():
inputvalue = usernameList.get("1.0","end-1c")
print(inputvalue)
#CSV Creator part
def csvGenerate():
basename= creator.get()
suffix = datetime.datetime.now().strftime("%Y%m%d%H%M.csv")
filename = "_".join([basename, suffix]) # e.g. 'Creator_120508171442'
df = pd.read_csv('Template.csv')
df2 = df.append(usernameList, ignore_index=True)
df.to_csv(filename, index=False, header=False)
#Generate button
GENERATE = Button(root, text="GENERATE", command=csvGenerate).grid(column=0, row=6, columnspan=3)
root.mainloop()
窗戶
編輯 20.10.2021:按照建議將我的代碼從 csv 更改為 pandas,但仍然不知道如何繼續。
uj5u.com熱心網友回復:
您可以使用 Pandas 生成 csv
import pandas as pd
data = {'Product': ['Desktop Computer','Tablet','Printer','Laptop'],
'Price': [850,200,150,1300]
}
df = pd.DataFrame(data, columns= ['Product', 'Price'])
df.to_csv (r'C:\Users\Ron\Desktop\export_dataframe.csv', index = False, header=True)
print (df)
編輯:您還有用于創建 CSV的csv包,但我更喜歡 Pandas,因為創建 dict 并將其轉換為 DataFrame -> csv 非常簡單。
uj5u.com熱心網友回復:
我建議使用 for 回圈創建復選按鈕,并將這些StringVars存盤在一個串列中,稍后可以輕松使用該串列來確定選擇了哪些角色。
請注意,使用csv模塊而不是pandas:
from tkinter import *
from tkinter import ttk
import datetime
import csv
root = Tk()
root.geometry('500x500')
root.title("Csv generator")
#Creator name
creator = Entry(root, width=23)
creator.grid(column=1, row=0)
creator.insert(0, "Enter here your username")
#Functions entry
Label(root, text="FUNCTION", width=10).grid(column=0, row=1, padx=10)
clickFunction = StringVar(value="Select your function")
OptionMenu(root, clickFunction, "add", "chg", "cho", "del").grid(column=0, row=2, padx=10)
#Username list
Label(root, text="USERNAME", width=10).grid(column=1, row=1, padx=10)
usernameList = Text(root, width=10, height=4)
usernameList.grid(column=1, row=1, padx=10, rowspan=4)
#Role List
Label(root, text="ROLES", width=10).grid(column=2, row=1, padx=10)
role_vars = [] # for storing those StringVars
# create the checkbuttons
for row, role in enumerate(("Role01", "Role02", "Role1", "Role2"), 2):
var1 = StringVar()
Checkbutton(root, text=role, variable=var1, onvalue=role, offvalue='').grid(row=row, column=2, padx=10, sticky='w')
role_vars.append(var1)
#CSV Creator part
def csvGenerate():
basename = creator.get()
suffix = datetime.datetime.now().strftime("%Y%m%d%H%M.csv")
filename = "_".join([basename, suffix]) # e.g. 'Creator_202110211234.csv'
with open(filename, "w", newline="") as file:
writer = csv.writer(file)
func = clickFunction.get() # use the StringVar instead
# get user list
users = usernameList.get('1.0', 'end-1c').splitlines()
# get selected roles
roles = [role.get() for role in role_vars if role.get()]
for user in users:
for role in roles:
writer.writerow([func, user, role])
#Generate button
Button(root, text="GENERATE", command=csvGenerate).grid(column=0, row=6, columnspan=3)
root.mainloop()
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/329526.html
