Python - 코드 실행 시간 측정

파이썬에서 코드의 수행 시간을 측정하는 다양한 방법을 소개합니다.

1. time.time() : 가장 간단한 실행 시간 측정하는 방법

time.time()은 UTC 시간을 초로 리턴합니다. UTC는 1970년 1월 1일을 기준으로 현재의 시간을 측정한 것입니다.

다음과 같이 반복문의 수행시간을 측정할 수 있습니다. 단위는 second이며, time()으로 측정된 시간은 CPU sleep 시간도 포함합니다.

import time

start_time = time.time()

for i in range(50000000):
    a = i * i

end_time = time.time()
elapsed_time = end_time - start_time

print(f"start_time: {start_time}")
print(f"end_time: {end_time}")
print(f"elapsed_time: {elapsed_time}")

Output:

start_time: 1643594780.8785496
end_time: 1643594784.6853516
elapsed_time: 3.8068020343780518

Nano second로 출력하고 싶다면 다음과 같이 time.time_ns()를 사용하시면 됩니다.

start_time = time.time_ns()
end_time = time.time_ns()
elapsed_time = end_time - start_time

2. time.perf_counter() : 정밀하게 실행 시간을 측정하는 방법

time.perf_counter()는 조금 더 정밀한 시간을 리턴합니다. 약간의 오차도 무시하기 어렵다면 perf_counter()를 사용하는 것이 좋습니다. 단위는 second이며, CPU sleep 시간을 포함합니다.

다음과 같이 코드 수행 시간을 측정할 수 있습니다.

import time

start_time = time.perf_counter()

for i in range(50000000):
    a = i * i

end_time = time.perf_counter()
elapsed_time = end_time - start_time

print(f"start_time: {start_time}")
print(f"end_time: {end_time}")
print(f"elapsed_time: {elapsed_time}")

Output:

start_time: 2143.54483939
end_time: 2147.450245089
elapsed_time: 3.905405698999857

Nano second로 출력하고 싶다면 다음과 같이 time.perf_counter_ns()를 사용하시면 됩니다.

start_time = time.perf_counter_ns()
end_time = time.perf_counter_ns()
elapsed_time = end_time - start_time

3. time.process_time() : CPU 실행 시간만 측정하는 방법(sleep 시간 제외)

time.process_time()는 CPU sleep 시간은 제외하고, 실제 CPU가 동작한 시간만 측정합니다.

아래 예제를 보시면, sleep(5)로 5초 sleep하고 있습니다. 하지만 측정된 수행 시간을 보면 3.6초입니다. sleep 시간은 측정하지 않고 CPU가 동작할 때만 시간이 계산된다는 것을 알 수 있습니다.

import time

start_time = time.process_time()

for i in range(50000000):
    a = i * i

time.sleep(5)

end_time = time.process_time()
elapsed_time = end_time - start_time

print(f"start_time: {start_time}")
print(f"end_time: {end_time}")
print(f"elapsed_time: {elapsed_time}")

Output:

start_time: 0.025630576
end_time: 3.630390994
elapsed_time: 3.6047604179999997

Nano second로 출력하고 싶다면 다음과 같이 time.process_time_ns()를 사용하시면 됩니다.

start_time = time.process_time_ns()
end_time = time.process_time_ns()
elapsed_time = end_time - start_time

References

Loading script...
codechachaCopyright ©2019 codechacha