0
我已经创建了一个使用wxFormBuilder的GUI,它应该允许用户在列表中输入“业务访问者”的名称,然后单击两个按钮之一以返回最多频繁和最不频繁的业务访客。这里看一下GUI:http://imgur.com/XJnvo0U最大和最小频率都返回相同的值
不幸的是,最大和最小按钮都抛出相同的值(大多数)。我认为这与频率如何加权输入有关,也许与clkFindMost和clkFindLeast事件的定义重叠有关。任何帮助将不胜感激。
**编辑:我非常新的Python,和学习曲线陡峭
import wx
import myLoopGUI
import commands
class MyLoopFrame(myLoopGUI.MyFrame1):
def __init__(self, parent):
myLoopGUI.MyFrame1.__init__(self, parent)
def clkAddData(self,parent):
if len(self.txtAddData.Value) != 0:
try:
myname = str(self.txtAddData.Value)
self.listMyData.Append(str(myname))
except:
wx.MessageBox("This has to be a name!")
else:
wx.MessageBox("This can't be empty")
def clkFindMost(self, parent):
name_list = set(self.listMyData.GetStrings())
unique_names = set(name_list)
frequencies = {}
for name in unique_names:
if frequencies.get(name):
frequencies[name] += 1
else:
frequencies[name] = 0
counts = list(frequencies.values())
names = list(frequencies.keys())
max_count_index = counts.index(max(counts))
min_count_index = counts.index(min(counts))
most_frequent = names[max_count_index]
least_frequent = names[min_count_index]
self.txtResults.Value = most_frequent
def clkFindLeast(self, parent):
name_list = set(self.listMyData.GetStrings())
unique_names = set(name_list)
frequencies = {}
for name in unique_names:
if frequencies.get(name):
frequencies[name] += 1
else:
frequencies[name] = 0
counts = list(frequencies.values())
names = list(frequencies.keys())
max_count_index = counts.index(max(counts))
min_count_index = counts.index(min(counts))
most_frequent = names[max_count_index]
least_frequent = names[min_count_index]
self.txtResults.Value = least_frequent
def clkClear (self, parent):
self.txtResults.SetValue("")
#Needed to ensure the program runs
myApp = wx.App(False)
myFrame = MyLoopFrame(None)
myFrame.Show()
myApp.MainLoop()
Ohhhh,好的。我现在明白了。我该如何纠正这一点? (就像我之前提到的,我对Python非常陌生) – 2014-10-02 01:29:33
这非常了解。不幸的是,我必须保持for循环和if/else结构作为这个任务的一部分。有没有一种非“优雅”的方式来解决这个问题? – 2014-10-02 01:45:06
我修改了我的答案。问题是你正在遍历唯一的名字,但你真的想遍历非单一列表。 – bernie 2014-10-02 02:14:18