鱼C论坛

 找回密码
 立即注册
查看: 2717|回复: 5

【提问】Tkinter 获取Entry输入值 '%P'不起作用

[复制链接]
发表于 2022-8-29 20:10:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我尝试了
from tkinter import *

master = Tk()

v = StringVar()

def tes(content, reason, name):
    if content == "小甲鱼":
        print("正确!")
        print(content, reason, name)
        return True
    else:
        print("错误!")
        print(content, reason, name)
        return False

tesCMD = master.register(tes)

e1 = Entry(master,
           textvariable=v,
           validate="focusout",
           validatecommand=(tesCMD, '%P','1','2'))
           # %P表示 当输入框的值允许改变,该值有效。该值为当前文本框内容
           # %v(小写大写不一样的),当前validate的值
           # %W表示该组件的名字
e2 = Entry(master)
e1.pack(padx=10, pady=10)
e2.pack(padx=10, pady=10)

mainloop()

可以运行
然后想在自己的代码中使用这个功能获取Entry内容并存入Excel,但不知道为什么存入excel的是字符串'%P'
下面是我的代码:
        def find_loc(enter):
            global wbname, locpoint
            subjects = pd.read_excel("C:\\Users\\86136\\.spyder-py3\\被试信息管理\\被试信息管理\\subject_load.xlsx")
            subject_id = subjects.values[-1][0]
            wbname = str(subject_id) + '.xlsx'
            subjects = pd.read_excel(
                "C:\\Users\\86136\\.spyder-py3\\被试信息管理\\被试信息管理\database\\{}".format(wbname))
            titleline = list(subjects.keys())
            locpoint = titleline.index(enter)

        def data_to_excel(data,titlename):
            find_loc(titlename)
            wb = openpyxl.load_workbook(
                "C:\\Users\\86136\\.spyder-py3\\被试信息管理\\被试信息管理\\database\\{}".format(wbname))
            ws = wb['basic_info']
            ws.cell(row=2, column=locpoint + 1).value = data
            wb.save("C:\\Users\\86136\\.spyder-py3\\被试信息管理\\被试信息管理\\database\\{}".format(wbname))
            wb.close()
                    
        
        def add_D():
            if self.f1:
                self.f1.destroy()
            self.f1 = tk.Frame(self.canvas)
            self.myscrollbar=tk.Scrollbar(self.myframe,orient="vertical",command=self.canvas.yview)
            self.canvas.configure(yscrollcommand=self.myscrollbar.set)
            self.myscrollbar.pack(side="right",fill="y")
            self.canvas.pack(side="left")
            self.canvas.create_window((0,0),window=self.f1,anchor='nw')
            self.f1.bind("<Configure>",self.myfunction)
              
            
            with open("C:\\Users\\86136\\.spyder-py3\\被试信息管理\\被试信息管理\\UKbiobank题库\\D.txt", 'r', encoding='utf-8') as Dtxt:  # 只读方式打开编码为utf-8的文本文件
                number = 0  # 文本文件中的行号,即
                line = Dtxt.readlines()  # 以读取一行为列表方法读取全部行,line为分解好的列表内容
                Q_num = len(line)
                rownum = 0
            for x in range(Q_num):
                str1 = line[x].split('*') 
                id = str(number+1)+". "  # 题目序号
                self.la1 = tk.Label(self.f1, text=str1[0]+', '+str1[1]+', '+str1[2], justify="left", height=2,
                              wraplength=500)  # 题目,靠左,多行左对齐
                self.la1.pack()

                op_num = len(str1)-3
                d2e = self.f1.register(data_to_excel)
                self.var = tk.IntVar()
                v = tk.StringVar()
                for i in range(0,op_num):
                    if '___' in str1[i]:                       
                        tk.Label(self.f1,text=str1[3]).pack()
                        self.ra1_entry = tk.Entry(self.f1, textvariable=v, validate="focusout", validatecommand=(d2e,'%P',str1[0]))
                        self.ra1_entry.pack()
                    else:                       
                        self.ra1 = tk.Radiobutton(self.f1, text=str(i+1)+', ' + str1[i+3], variable=self.var,
                                                  value=i+1, justify="left", wraplength=430, command=(d2e,'%P',str1[0]))
                        self.ra1.pack()    
                
                rownum += op_num+1 

            self.thank=tk.Label(self.f1,text='请点击右下角的确认保存,然后点击左下角的菜单返回').pack()
            self.btn1 = tk.Button(self.f1, text='菜单', command=menu)
            self.btn1.pack(side='left')   
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-8-29 23:46:28 | 显示全部楼层
资源代码打包上传。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-30 17:50:16 | 显示全部楼层
ba21 发表于 2022-8-29 23:46
资源代码打包上传。

请问怎么上传?有哪个帖子有写吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-30 18:45:27 | 显示全部楼层
chenjl1 发表于 2022-8-30 17:50
请问怎么上传?有哪个帖子有写吗?

2022830_184512.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-30 19:14:55 | 显示全部楼层

新人好像传不了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-30 19:15:46 | 显示全部楼层
我发现了,Entry里的‘%P’是可以工作的,Radiobutton有没有类似功能的代码?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-26 08:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表