Tag: 循环

Python Lambda在一个循环中

考虑下面的代码片段: # directorys == {'login': <object at …>, 'home': <object at …>} for d in directorys: self.command["cd " + d] = (lambda : self.root.change_directory(d)) 我期望创build一个两个函数的字典如下: # Expected : self.command == { "cd login": lambda: self.root.change_directory("login"), "cd home": lambda: self.root.change_directory("home") } 但它看起来像生成的两个lambda函数是完全一样的: # Result : self.command == { "cd login": lambda: self.root.change_directory("login"), "cd home": lambda: self.root.change_directory("login") […]

在Java中迭代列表的方法?

对于Java语言来说,我尝试熟悉所有的方法(或者至less是非病态方法),以便可以遍历列表(或者其他集合)以及每个方法的优缺点。 给定一个List<E> list对象,我知道以下方法遍历所有元素: 基本的 循环 (当然,在do while循环中也有等价的) // Not recommended (see below)! for (int i = 0; i < list.size(); i++) { E element = list.get(i); // 1 – can call methods of element // 2 – can use i to make index-based calls to methods of list // … } 注意:正如@a​​marseillan所指出的那样,这个表单对迭代List s来说是一个糟糕的select,因为get方法的实际实现可能不如使用Iterator时那样高效。 例如, LinkedList实现必须遍历i之前的所有元素才能获得第i个元素。 […]

如何循环在JSP中的HashMap?

我如何循环JSP中的HashMap ? <% HashMap<String, String> countries = MainUtils.getCountries(l); %> <select name="country"> <% // Here I need to loop through countries. %> </select>

Python 2.X中的range和xrange函数有什么区别?

显然xrange是更快,但我不知道为什么它更快(除了轶事迄今没有证据,它是更快),或除此之外是什么不同 for i in range(0, 20): for i in xrange(0, 20):

我如何迭代JSON结构?

我有以下JSON结构: [{ "id":"10", "class": "child-of-9" }, { "id": "11", "classd": "child-of-10" }] 如何使用jQuery或JavaScript迭代它?

调用在Java中的foreach循环中删除

在Java中,使用foreach循环遍历集合时调用集合上的remove是否合法? 例如: List<String> names = …. for (String name : names) { // Do something names.remove(name). } 作为附录,删除尚未被迭代的项目是否合法? 例如, //Assume that the names list as duplicate entries List<String> names = …. for (String name : names) { // Do something while (names.remove(name)); }

迭代时修改列表

l = range(100) for i in l: print i, print l.pop(0), print l.pop(0) 上面的python代码给出了与预期完全不同的输出。 我想循环的项目,以便我可以跳过一个项目,而循环。 请解释。

如何从一个通用列表中删除元素,而迭代呢?

我正在寻找一个更好的模式来处理每个需要处理的元素列表,然后根据结果从列表中删除。 你不能在foreach (var element in X)使用.Remove(element) foreach (var element in X) (因为它导致Collection was modified; enumeration operation may not execute. 。exception)…你也不能使用for (int i = 0; i < elements.Count(); i++)和.RemoveAt(i)因为它扰乱了你在集合中相对于i当前位置。 有没有一个优雅的方式来做到这一点?

加快R中的循环操作

我在R中有一个很大的性能问题。我写了一个迭代data.frame对象的函数。 它只是添加一个新的列data.frame和积累的东西。 (操作简单)。 data.frame大约有850K行。 我的电脑还在工作(现在大约10小时),我不知道运行时间。 dayloop2 <- function(temp){ for (i in 1:nrow(temp)){ temp[i,10] <- i if (i > 1) { if ((temp[i,6] == temp[i-1,6]) & (temp[i,3] == temp[i-1,3])) { temp[i,10] <- temp[i,9] + temp[i-1,10] } else { temp[i,10] <- temp[i,9] } } else { temp[i,10] <- temp[i,9] } } names(temp)[names(temp) == "V10"] <- "Kumm." return(temp) […]

在Java中打破嵌套循环

我有一个像这样的嵌套循环结构: for (Type type : types) { for (Type t : types2) { if (some condition) { // Do something and break… break; // Breaks out of the inner loop } } } 现在我怎么能摆脱两个循环。 我看过类似的问题,但是没有一个关于Java的具体问题。 我不能应用这些解决scheme,因为大多数使用gotos。 我不想把内部循环放在一个不同的方法中。 更新:我不想重新运行循环,当打破我完成循环块的执行。