2014-01-05 2 views
0

Что не так с моим параметром настройки в следующем?Импортирование вложенных функций в timeit

import timeit 
import random 
from copy import copy 

def shortBubbleSort(aList): 
    n = len(aList) - 1 
    iterating = True 
    while n > 0 and iterating: 
     iterating = False 
     for i in range(n): 
      if aList[i+1] < aList[i]: 
       iterating = True 
       aList[i], aList[i+1] = aList[i+1], aList[i] 
     n -= 1 
    return aList 


L = [] 
for i in range(1,500): 
    L.append(random.randrange(0,1000000)) 

x = timeit.repeat("bubbleSort(copy(L))", setup="from __main__ import bubbleSort,copy,L",repeat = 100,number = 100) 
y = (sum(x)/len(x))*100 
print(str(y)) 

Я также попытался следующие:

  • setup="from __main__ import bubbleSort,from copy import copy"
  • setup="from __main__ import bubbleSort,copy"
  • setup="from __main__ import bubbleSort"

TraceBack следующим образом:

Traceback (most recent call last): 
    File "C:\Users\Administrator\AppData\Local\ActiveState\KomodoEdit\7.1\samples\bubbleSort TimeIt.py", line 24, in <module> 
    x = timeit.repeat("bubbleSort(copy(L))", setup="from __main__ import bubbleSort,copy,L",repeat = 100,number = 100) 
    File "C:\Python32\lib\timeit.py", line 235, in repeat 
    return Timer(stmt, setup, timer).repeat(repeat, number) 
    File "C:\Python32\lib\timeit.py", line 223, in repeat 
    t = self.timeit(number) 
    File "C:\Python32\lib\timeit.py", line 195, in timeit 
    timing = self.inner(it, self.timer) 
    File "<timeit-src>", line 3, in inner 
ImportError: cannot import name bubbleSort 
+0

Какая ошибка? – mgilson

+2

Хорошо, что заставляет вас думать, что с этим что-то не так? Вы получили сообщение об ошибке? Если это так, пожалуйста, покажите полный трафик. – delnan

+0

ok - добавит сейчас ... хотя я знаю, что это была опечатка. – whytheq

ответ

0

Возможно, опечатка. Фактическое имя функции shortBubbleSort и вы импортируете bubbleSort

На моей машине, результат был

192.437240362 
+0

+1 .... кричит: где смущенная шляпа? – whytheq

0

Это опечатка. Ваша функция называется shortBubbleSort, а не bubbleSort. Это работает:

x = timeit.repeat("shortBubbleSort(copy(L))", setup="from __main__ import shortBubbleSort,copy,L",repeat = 100,number = 100) 
Смежные вопросы