- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已经为文件对话框创建了一个按钮、一个条目和一个函数。在我按下“浏览”按钮后,文件对话框没有出现,所以我如何确保我的 custName.set(filename)
可以在我的 TracingMethod () 函数中使用。
创建文件对话框的步骤:
第 1 步:从 tkinter 导入文件对话框
from tkinter import filedialog
第二步:创建按钮和条目
self.browseButton = Button(self.radioframe, text="Browse",command = self.open)
self.browseButton.grid(row =3, column =3, sticky = W)
#Define the entry
custName = StringVar(None)
location_ent =Entry(self.radioframe,textvariable = custName)
location_ent.grid(row =2, column = 2, sticky = W,columnspan=1)
location_ent.update()
location_ent.focus_set()
第三步:创建open()函数【IDE在这里显示错误】
def open():
filename = filedialog.askopenfilename(parent=root,title='Choose a file')
custName.set(filename)
我在想的是我是在独家新闻之外定义函数吗?所以我提供了完整的代码以供引用。
from tkinter import *
from tkinter import filedialog
class TracingInterface(Frame):
def __init__(self, master):
super().__init__()
master.minsize(width=700, height=520)
master.maxsize(width=700, height=520)
Grid.config(self)
self.TracingMethod()
self.logDetails()
self.otherFunctionInterface()
def TracingMethod(self):
self.traceMethodSelect = StringVar()
self.traceMethodSelect.set("LT")
self.radioframe = LabelFrame(self,text="Tracing Method",height= 120,width =300)
self.radioframe.grid(row= 0, column=0)
self.radioframe.grid_propagate(0)
self.radioframe.LT= Radiobutton(
self.radioframe, text="Live Tracing",
variable=self.traceMethodSelect, value="LT",
anchor=W).grid(row=1, column = 0, sticky = W,columnspan=2)
self.radioframe.SL= Radiobutton(
self.radioframe, text="Specific Location",
variable=self.traceMethodSelect, value="SL",
anchor=W).grid(row=2, column = 0, sticky = W,columnspan=2)
self.traceButton = Button(self.radioframe, text="Trace")
self.traceButton.grid(row =3, column =0, sticky = W)
self.cancelButton = Button(self.radioframe, text="Cancel")
self.cancelButton.grid(row =3, column =1, sticky = W)
self.configUAButton = Button(self.radioframe, text="Configuration",command=printMessage)
self.configUAButton.grid(row =3, column =2, sticky = W)
self.configUAButton.config(width=15)
self.browseButton = Button(self.radioframe, text="Browse",command = self.open)
self.browseButton.grid(row =3, column =3, sticky = W)
custName = StringVar(None)
location_ent =Entry(self.radioframe,textvariable = custName)
location_ent.grid(row =2, column = 2, sticky = W,columnspan=1)
location_ent.update()
location_ent.focus_set()
def logDetails(self):
self.logframe = LabelFrame(self,text="Log Details",height= 520,width =390,padx=15)
self.logframe.grid_propagate(0)
self.logframe.grid_rowconfigure(0,weight =1)
self.logframe.grid_columnconfigure(0,weight=1)
xscrollbar = Scrollbar(self.logframe,orient = HORIZONTAL)
xscrollbar.grid(row=1, column=1, sticky=E+W,columnspan=2)
yscrollbar = Scrollbar(self.logframe,orient= VERTICAL)
yscrollbar.grid(row=0, column=3, sticky=N+S)
text = Text(self.logframe,width=50,height=50, wrap=NONE, xscrollcommand=xscrollbar.set,
yscrollcommand=yscrollbar.set)
text.grid(row=0, column=1, columnspan=2)
# attach listbox to scrollbar
xscrollbar.config(command=text.xview)
yscrollbar.config(command=text.yview)
button_1 = Button(self.logframe, text="View", command=printMessage,width =10)
button_1.grid(row=2,column= 1)
button_2 = Button(self.logframe, text="Export", command=printMessage,width =10)
button_2.grid(row=2,column= 2)
self.logframe.grid(row=0,column =1,rowspan=5)
def otherFunctionInterface(self):
self.otherFrame = LabelFrame(self,text="Other Function",height= 400,width =300)
self.otherFrame.grid(row=4, column=0)
self.otherFrame.grid_propagate(0)
OpenPreviousCaseFile = Button(self.otherFrame, text="Open previous case file", command=printMessage,height = 4,
width =21)
OpenPreviousCaseFile.grid(row=5,column= 0,pady=5,padx=5)
OpenPreviousTracingResult = Button(self.otherFrame, text="Open last tracing result ", command=printMessage,
height = 4, width =21)
OpenPreviousTracingResult.grid(row=6,column= 0,pady=5,padx=5)
OpenMenualbtn = Button(self.otherFrame, text="User manual", command=printMessage,height =4, width =21)
OpenMenualbtn.grid(row=7,column= 0,pady=5,padx=5)
AboutBtn = Button(self.otherFrame, text="About", command=printMessage,height = 4, width =21)
AboutBtn.grid(row=8,column= 0,pady=5,padx=5)
locateCaseFile = Entry(self.otherFrame)
locateCaseFile.grid(row=5,column = 1)
locateTraceResult = Entry(self.otherFrame)
locateTraceResult.grid(row=6,column = 1)
def open():
filename = filedialog.askopenfilename(parent=root,title='Choose a file')
custName.set(filename)
def printMessage():
print("Wow this actually worked!")
if __name__=='__main__':
root=Tk()
root.title("Windows User Activity History Tracing and Analysing System")
tif= TracingInterface(root)
root.mainloop()
最佳答案
self.browseButton
小部件没有出现,因为您将 location_ent
的 columnspan
选项设置为 1。您必须将其修改为 2,因为您有 自己。 configUAButton
按钮也在那里。
这意味着您需要更改:
location_ent.grid(row =2, column = 2, sticky = W,columnspan=1)
收件人:
location_ent.grid(row =2, column = 2, sticky = W,columnspan=2)
但是您现在几乎不能self.browseButt
,因为您为self.radioframe
设置的宽度不够。所以改变这一行:
self.radioframe = LabelFrame(self,text="Tracing Method",height= 120,width =300)
到:
self.radioframe = LabelFrame(self,text="Tracing Method",height= 120,width =355)
当然,您需要相应地修改master
窗口的width
选项。为此,更改:
master.minsize(width=700, height=520)
master.maxsize(width=700, height=520)
最后,您无法访问 custName
,因为您需要将其设为 instance variable反而。这意味着您需要更改:
self.custName = StringVar(None)
location_ent =Entry(self.radioframe,textvariable = self.custName)
收件人:
self.custName = StringVar(None)
location_ent =Entry(self.radioframe,textvariable = self.custName)
收件人:
master.minsize(width=755, height=520)
master.maxsize(width=755, height=520)
并且(因此)在 open()
方法中:
custName.set(filename)
收件人:
self.custName.set(filename)
让我们把前面提到的所有内容放在一起:
from tkinter import *
from tkinter import filedialog
class TracingInterface(Frame):
def __init__(self, master):
super().__init__()
master.minsize(width=755, height=520)
master.maxsize(width=755, height=520)
Grid.config(self)
self.TracingMethod()
self.logDetails()
self.otherFunctionInterface()
def TracingMethod(self):
self.traceMethodSelect = StringVar()
self.traceMethodSelect.set("LT")
# Bill
self.radioframe = LabelFrame(self,text="Tracing Method",height= 120,width =355)
self.radioframe.grid(row= 0, column=0)
self.radioframe.grid_propagate(0)
self.radioframe.LT= Radiobutton(
self.radioframe, text="Live Tracing",
variable=self.traceMethodSelect, value="LT",
anchor=W).grid(row=1, column = 0, sticky = W,columnspan=2)
self.radioframe.SL= Radiobutton(
self.radioframe, text="Specific Location",
variable=self.traceMethodSelect, value="SL",
anchor=W).grid(row=2, column = 0, sticky = W,columnspan=2)
self.traceButton = Button(self.radioframe, text="Trace")
self.traceButton.grid(row =3, column =0, sticky = W)
self.cancelButton = Button(self.radioframe, text="Cancel")
self.cancelButton.grid(row =3, column =1, sticky = W)
self.configUAButton = Button(self.radioframe, text="Configuration",command=printMessage)
self.configUAButton.grid(row =3, column =2, sticky = W)
self.configUAButton.config(width=15)
self.browseButton = Button(self.radioframe, text="Browse",command = self.open)
self.browseButton.grid(row =3, column =3, sticky = W)
# Bill
self.custName = StringVar(None)
location_ent =Entry(self.radioframe,textvariable = self.custName)
# Bill
location_ent.grid(row =2, column = 2, sticky = W,columnspan=2)
location_ent.update()
location_ent.focus_set()
def logDetails(self):
self.logframe = LabelFrame(self,text="Log Details",height= 520,width =390,padx=15)
self.logframe.grid_propagate(0)
self.logframe.grid_rowconfigure(0,weight =1)
self.logframe.grid_columnconfigure(0,weight=1)
xscrollbar = Scrollbar(self.logframe,orient = HORIZONTAL)
xscrollbar.grid(row=1, column=1, sticky=E+W,columnspan=2)
yscrollbar = Scrollbar(self.logframe,orient= VERTICAL)
yscrollbar.grid(row=0, column=3, sticky=N+S)
text = Text(self.logframe,width=50,height=50, wrap=NONE, xscrollcommand=xscrollbar.set,
yscrollcommand=yscrollbar.set)
text.grid(row=0, column=1, columnspan=2)
# attach listbox to scrollbar
xscrollbar.config(command=text.xview)
yscrollbar.config(command=text.yview)
button_1 = Button(self.logframe, text="View", command=printMessage,width =10)
button_1.grid(row=2,column= 1)
button_2 = Button(self.logframe, text="Export", command=printMessage,width =10)
button_2.grid(row=2,column= 2)
self.logframe.grid(row=0,column =1,rowspan=5)
def otherFunctionInterface(self):
self.otherFrame = LabelFrame(self,text="Other Function",height= 400,width =300)
self.otherFrame.grid(row=4, column=0)
self.otherFrame.grid_propagate(0)
OpenPreviousCaseFile = Button(self.otherFrame, text="Open previous case file", command=printMessage,height = 4,
width =21)
OpenPreviousCaseFile.grid(row=5,column= 0,pady=5,padx=5)
OpenPreviousTracingResult = Button(self.otherFrame, text="Open last tracing result ", command=printMessage,
height = 4, width =21)
OpenPreviousTracingResult.grid(row=6,column= 0,pady=5,padx=5)
OpenMenualbtn = Button(self.otherFrame, text="User manual", command=printMessage,height =4, width =21)
OpenMenualbtn.grid(row=7,column= 0,pady=5,padx=5)
AboutBtn = Button(self.otherFrame, text="About", command=printMessage,height = 4, width =21)
AboutBtn.grid(row=8,column= 0,pady=5,padx=5)
locateCaseFile = Entry(self.otherFrame)
locateCaseFile.grid(row=5,column = 1)
locateTraceResult = Entry(self.otherFrame)
locateTraceResult.grid(row=6,column = 1)
def open(self):
filename = filedialog.askopenfilename(parent=root,title='Choose a file')
# Bill
self.custName.set(filename)
def printMessage():
print("Wow this actually worked!")
if __name__=='__main__':
root=Tk()
root.title("Windows User Activity History Tracing and Analysing System")
tif= TracingInterface(root)
root.mainloop()
下面是运行上面程序的截图:
关于Python:打开文件对话框没有出现,因为无法访问文本变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38430257/
表架构 DROP TABLE bla; CREATE TABLE bla (id INTEGER, city INTEGER, year_ INTEGER, month_ INTEGER, val I
我需要拆分字符串/或从具有以下结构的字符串中获取更容易的子字符串。 字符串将来自 window.location.pathname 或 window.location.href,看起来像 text/n
每当将对象添加到数组中时,我都会尝试更新 TextView ,并在 TextView 中显示该文本,如下所示: "object 1" "object 2" 问题是,每次将新对象添加到数组时,它都会覆盖
我目前正在寻找使用 Java 读取网站可见文本并将其存储为纯文本字符串的方法。 换句话说,我想转换成这样: Hello stupid World进入“ Hello World ” 或者类似的东西 Un
我正在尝试以文本和 HTML 格式发送电子邮件,但无法正确发送正确的 header 。特别是,我想设置 Content-Type header ,但我找不到如何为 html 和文本部分单独设置它。 这
我尝试了上面的代码,但我无法绑定(bind)文本,我怎样才能将资源内部文本 bloc
我刚刚完成了 Space Shooter 教程,由于没有 GUIText 对象,所以我创建了 UI.Text 对象并进行了相应的编码。它在统一播放器中有效,但在构建 Web 应用程序后无效。我花了一段
我有这个代码: - (IBAction)setButtonPressed:(id)sender { NSUserDefaults *sharedDefaults = [[NSUserDefau
抱歉标题含糊不清,但我想不出我想在标题中做什么。无论如何,对于图像上的文本,我使用了 JLabel 文本并将其添加到图标中。 JLabel icon = new JLabel(new Imag
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我在将 Twitter 嵌入到我从 HTML 5 转换的 wordpress 运行网站时遇到问题。 我遇到的问题是推文不是我的自定义字体... 这是我无法使用任何 css 定位的 HTML 代码,我正
我正在尝试找到解决由于使用以下形式的代码而导致的冗余字符串连接问题的最佳方法: logger.debug("Entering loop, arg is: " + arg) // @1 在大多数情况下,
我写了这个测试 @Test public void removeRequestTextFromRouteError() throws Exception { String input = "F
我目前正在创建一个正则表达式来拆分所有匹配以下格式的字符串:&[文本],并且需要获取文本。字符串可能类似于:something &[text] &[text] everything &[text] 等
有没有办法将标题文本从一个词变形为另一个词,同时保留两个词中使用的字母?我看过的许多 css 文本动画大多是视觉的,很少有旋转整个单词的。 我想要做的是从一个词过渡,例如“BEACH”到“CHANGE
总结matplotlib绘图如何设置坐标轴刻度大小和刻度。 上代码: ?
我在容器 (1) 中创建了容器 (2)。你能帮忙如何向容器(1)添加文本吗?下面是我的代码 return Scaffold( body: Padding( padding: c
我似乎找不到任何人或任何人这样做过。我试图限制我们使用的图像数量,并想创建一个带有渐变作为其“颜色”的文本,并在其周围设置渐变轮廓/描边 到目前为止,我还没有看到任何将两者结合在一起的东西。 我可以自
我正在为视频游戏暗黑破坏神 2 使用 discord.py 构建一个不和谐机器人。其中一项功能要求机器人从暗黑破坏神 2 屏幕截图中提取项目的名称和属性。我目前正在为此使用 pytesseract,但
我很难弄清楚如何旋转 strip.text theme 中的属性来自 ggplot2 .我使用的是 R 版本 3.4.2 和 ggplot2 版本 2.2.1。 以下是 MWE 的数据。 > dput
我是一名优秀的程序员,十分优秀!