使用Python 3.4
我有办法,但我认为可能有更好的方法。
我希望有一个方法expand()
的列表,它从列表中选择一个随机元素,但每次选择该元素时,计数器都会递增。我尝试将str
子类化,以便能够添加属性,但它没有用。
我所遇到的主要问题是表达式random.randint(0,len(self)-1)
并且使用局部变量似乎不是Pythonic。在我添加计数器之前,我只需输入random.choice(self)
class clauses(list):
def __init__(self):
self.uses = []
def __setitem__(self,key,value):
self.uses[key]=value
super().__setitem__(self,key,value)
def __delitem__(self,key):
del(self.uses[key])
super().__delitem__(key)
def append(self,value):
self.uses.append(0)
super().append(value)
def extend(self,sequence):
for x in sequence:
self.uses.append(0)
super().append(x)
def expand(self):
n = random.randint(0,len(self)-1)
self.uses[n] += 1
return(self[n])
答案 0 :(得分:1)
假设列表中没有重复的条目,初始化空字典以及列表应解决此问题。
在列表中添加元素时,您还可以通过myDict[element]=0
将其添加到字典中,其中myDict
是已初始化的字典,element
是要添加到列表中的项目
然后,当选择该项目时,您只需执行:myDict[element]+=1
。
当处理重复条目的实例时,您可以创建一个字典字典,其中字典中的每个key
都是一个单词,并且每个单词的嵌套字典keys
是,例如,重复单词的索引位置(当然是实际计数的值)。但是,这会增加实质性的复杂性,因为当您从列表中删除项目时,您还需要更新索引位置。这个嵌套的数据结构虽然如此:{ word1: {position1: count1}, word2: {position1: count1, position 2: count2}....}