我很惊讶地发现Python比PHP更慢以获得索引位置.有没有办法提高Python的性能?
例如:
在PHP中它花了:18.169965982437
<?PHP
$time_start = microtime(true);
$needle = file_get_contents("needle.wav", false, null, 46);
foreach(range(0, 10000) as $num) {
$haystack = file_get_contents("haystack.wav");
$match = strpos($haystack,$needle);
}
$time_end = microtime(true);
$finishTime = $time_end - $time_start;
echo $finishTime;
?>
在Python中它花了:23.6319999695
import time
import math
def microtime(get_as_float = False) :
if get_as_float:
return time.time()
else:
return '%f %d' % math.modf(time.time())
time_start = microtime(True)
needle = open("needle.wav","rb").read()
for x in range(0, 10000):
haystack = open("haystack.wav","rb").read()
match = haystack.index(needle[46:])
time_end = microtime(True)
finishTime = time_end - time_start
print finishTime
解决方法:
等效的python代码是这样的:
needle = open("needle.wav", "rb").read()[46:]
for x in range(0, 10000):
haystack = open("haystack.wav", "rb").read()
match = haystack.index(needle)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。