파이썬에서 코드의 수행 시간을 측정하는 다양한 방법을 소개합니다.
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.8068020343780518Nano second로 출력하고 싶다면 다음과 같이 time.time_ns()를 사용하시면 됩니다.
start_time = time.time_ns()
end_time = time.time_ns()
elapsed_time = end_time - start_time2. 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.905405698999857Nano second로 출력하고 싶다면 다음과 같이 time.perf_counter_ns()를 사용하시면 됩니다.
start_time = time.perf_counter_ns()
end_time = time.perf_counter_ns()
elapsed_time = end_time - start_time3. 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.6047604179999997Nano second로 출력하고 싶다면 다음과 같이 time.process_time_ns()를 사용하시면 됩니다.
start_time = time.process_time_ns()
end_time = time.process_time_ns()
elapsed_time = end_time - start_timeReferences
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)