Tag: for loop

什么是通过pandas循环数据框的最有效的方法?

我想以顺序的方式对数据框中的财务数据执行我自己的复杂操作。 例如,我正在使用以下来自雅虎财经的 MSFT CSV文件: Date,Open,High,Low,Close,Volume,Adj Close 2011-10-19,27.37,27.47,27.01,27.13,42880000,27.13 2011-10-18,26.94,27.40,26.80,27.31,52487900,27.31 2011-10-17,27.11,27.42,26.85,26.98,39433400,26.98 2011-10-14,27.31,27.50,27.02,27.27,50947700,27.27 …. 然后我做了以下几点: #!/usr/bin/env python from pandas import * df = read_csv('table.csv') for i, row in enumerate(df.values): date = df.index[i] open, high, low, close, adjclose = row #now perform analysis on open/close based on date, etc.. 那是最有效的方法吗? 考虑到pandas的速度的重点,我会假设必须有一个特殊的函数遍历值的方式,也可以检索索引(可能通过一个生成器是内存效率)? df.iteritems不幸的是只能逐列迭代。

我如何摆脱斯卡拉循环?

我如何打破循环? var largest=0 for(i<-999 to 1 by -1) { for (j<-i to 1 by -1) { val product=i*j if (largest>product) // I want to break out here else if(product.toString.equals(product.toString.reverse)) largest=largest max product } } 如何将嵌套循环转换为尾recursion? 从FPSDEM 2009的Scala讲座http://www.slideshare.net/Odersky/fosdem-2009-1013261在第22页: 打破并继续斯卡拉没有他们。 为什么? 他们有点必要; 更好地使用许多较小的函数问题如何与闭包进行交互。 他们不需要! 什么是解释?

批处理:如何在parsing输出时纠正variables覆盖不当行为

在batch file中,我正在检查Baseboard信息,其中包含以下内容: BaseboardCheck.cmd @echo off setlocal enabledelayedexpansion for /f "tokens=1,2* delims==" %%a in ('wmic baseboard get /format:list') DO ( if ["%%a"] EQU ["Product"] ( set PlatformInfo=%%b if defined PlatformInfo ( echo.!PlatformInfo! echo.!PlatformInfo!This overwrites the variable ) ) if ["%%a"] EQU ["Version"] ( set BaseboardVersion=%%b if defined BaseboardVersion ( echo.!BaseboardVersion! echo.!BaseboardVersion!This overwrites the variable ) ) […]

循环和遍历列表

这是一个代码片段,它给出了输出: 0 1 2 2 。 我期望输出3 3 3 3因为a[-1]访问列表中的数字3。 在网上给出的解释说:“ a[-1]的价值在每次迭代改变”,但我不明白如何或为什么。 任何解释将是伟大的! a = [0, 1, 2, 3] for a[-1] in a: print(a[-1])

Postgres – 数组for循环

我在写一个plpgsql脚本。 我想从二维数组中逐个获取数组内容。 DECLARE m varchar[]; arr varchar[][] := array[['key1','val1'],['key2','val2']]; BEGIN for m in select arr LOOP raise NOTICE '%',m; END LOOP; END; 但是上面的代码返回 {{key1,val1},{key2,val2}} 在一行中。 我想能够循环,并调用另一个函数,它需要像这样的参数: another_func(key1,val1)

JavaScript for循环索引奇怪

我对JS比较陌生,所以这可能是一个常见的问题,但是在处理for循环和onclick函数时我注意到了一些奇怪的东西。 我能够用这个代码复制问题: <html> <head> <script type="text/javascript"> window.onload = function () { var buttons = document.getElementsByTagName('a'); for (var i=0; i<2; i++) { buttons[i].onclick = function () { alert(i); return false; } } } </script> </head> <body> <a href="">hi</a> <br /> <a href="">bye</a> </body> </html> 点击链接时,我希望得到'0'和'1',但是我得到'2'。 为什么是这样? 顺便说一下,我设法通过使用“this”关键字来解决我的特定问题,但是我仍然对这种行为背后的问题感到好奇。

C:for循环int初始声明

有人可以详细解释下面的gcc错误吗? $ gcc -o Ctutorial/temptable.out temptable.c temptable.c: In function 'main': temptable.c:5: error: 'for' loop initial declaration used outside C99 mode temptable.c: … /* print Fahrenheit-Celsius Table */ main() { for(int i = 0; i <= 300; i += 20) { printf("F=%d C=%d\n",i, (i-32) / 9); } } PS:我依稀记得, int i应该在for循环之前声明。 我应该说,我正在寻找一个给出C标准历史背景的答案。

在循环中使用对象

为什么不可以使用循环中的对象? 或者这是一个浏览器错误? 这段代码在Chrome 42中不起作用,说undefined不是一个函数: test = { first: "one"} for(var item of test) { console.log(item) }

迭代器vs

我在采访中被问到使用迭代器使用for循环的优点是什么,或者使用循环迭代器有什么优势? 任何机构都可以回答,以便将来如果我面临类似的问题,那么我可以回答

对于MySQL中的循环例子

在MySQL中,我有这个存储过程中有一个For循环: DELIMITER $$ CREATE PROCEDURE ABC() BEGIN DECLARE a INT Default 0 ; simple_loop: LOOP SET a=a+1; select a; IF a=5 THEN LEAVE simple_loop; END IF; END LOOP simple_loop; END $$ 它总是打印1 。 什么是MySQL for循环的正确语法?