파이썬에서 코드의 수행 시간을 측정하는 다양한 방법을 소개합니다.
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...
Related Posts
- Python - Yaml 파일 파싱하는 방법
- Python - 파일 내용 삭제
- Python - for문에서 리스트 순회 중 요소 값 제거
- Python - 두 리스트에서 공통 요소 값 찾기
- Python - 문자열 앞(뒤)에 0으로 채우기
- Python - 공백으로 문자열 분리
- Python - 중첩 리스트 평탄화(1차원 리스트 변환)
- Python - 16진수 문자열을 Int로 변환
- Python - 두 날짜, 시간 비교
- Python f-string으로 변수 이름, 값 쉽게 출력 (변수명 = )
- Python - nonlocal과 global 사용 방법
- Python 바다코끼리 연산자 := 알아보기
- Python - pip와 requirements.txt로 패키지 관리
- Python - 딕셔너리 보기 좋게 출력 (pprint)
- Python - Requests 사용 방법 (GET/POST/PUT/PATCH/DELETE)
- Python - 온라인 컴파일러 사이트 추천
- Python - os.walk()를 사용하여 디렉토리, 파일 탐색
- Python - 문자열 비교 방법
- Python - Text 파일 읽고 쓰는 방법 (read, write, append)
- Python - 리스트에서 첫번째, 마지막 요소 가져오는 방법
- Python - 두개의 리스트 하나로 합치기
- Python - 리스트의 마지막 요소 제거
- Python - 리스트의 첫번째 요소 제거
- Python 소수점 버림, 4가지 방법
- Python 코드 안에서 버전 확인 방법
- Python 소수점 반올림, round() 예제
- Python - 리스트 평균 구하기, 3가지 방법
- Python - bytes를 String으로 변환하는 방법
- Python - String을 bytes로 변환하는 방법
- Python 버전 확인 방법 (터미널, cmd 명령어)
- Python - 람다(Lambda) 함수 사용 방법
- Python - dict 정렬 (Key, Value로 sorting)
- Python - range() 사용 방법 및 예제
- Python - 리스트를 문자열로 변환
- Python - 문자를 숫자로 변환 (String to Integer, Float)