PYQT TUTORIAL
Cách chia List thành các phần bằng nhau trong Python Cách xóa một khóa (key) ra khỏi dictionary trong Python Hướng dẫn chuyển đổi file Google Colab sang Markdown trong Python Hướng dẫn LangChain bằng Python Cách tự viết Context Manager trong Python Cách background của hình ảnh trong Python Cách làm việc với Notion API trong Python Cách đo Time chạy trong Python Cách sao chép danh sách (List) trong Python PyQt là gì? Tạo một chương trình "Hello World". Tín hiệu và Khe (Signals & Slots) trong PyQt Cách sử dụng widget PyQt QLabel Cách sử dụng widget QPushButton của PyQt Cách sử dụng widget QLineEdit trong PyQt Cách sử dụng QVBoxLayout trong PyQt Cách sử dụng QGridLayout trong PyQt Cách sử dụng QFormLayout trong PyQt Cách sử dụng lớp QCheckBox trong PyQt Cách sử dụng lớp PyQt QRadioButton Sử dụng PyQt QComboBox để tạo Widget Combobox Cách sử dụng widget PyQt QSpinBox để tạo một spin box Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider). Cách dùng PyQt QWidget để làm container chứa các widget khác. Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ Cách sử dụng lớp PyQt QMenu để tạo menu Cách dùng lớp PyQt QToolBar để tạo các widget toolbar Cách dùng lớp QDockWidget của PyQt để tạo một widget Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar Cách sử dụng lớp QListWidget trong Python Cách sử dụng lớp QTableWidget để tạo một bảng Cách sử dụng lớp QTreeWidget của PyQt Cách sử dụng Qt Designer để thiết kế UX/UI trong PyQt. Cách sử dụng QThread trong PyQt Cách tạo các lớp QThreadPool đa luồng trong PyQt Cách hoạt động của Model/View trong PyQt Cách sử dụng Qt Style Sheets (QSS) trong PyQt. Chuyển đổi PyQt sang EXE trong PyQt
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Cách đo Time chạy trong Python

Trong Python, việc đo lường thời gian thực thi của mã là một kỹ năng quan trọng giúp bạn đánh giá và tối ưu hóa hiệu suất chương trình. Python cung cấp nhiều phương pháp đo thời gian từ đơn giản đến nâng cao, giúp bạn dễ dàng theo dõi thời gian chạy của các đoạn mã, từ đó phát hiện và cải thiện các phần cần tối ưu. Hãy cùng tìm hiểu các cách khác nhau để đo thời gian thực thi trong Python và tìm hiểu phương pháp nào phù hợp nhất cho nhu cầu của bạn.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Sử dụng time.time() trong Python

Bạn có thể sử dụng time.time() để lấy thời gian hiện tại trước và sau khi chạy đoạn mã cần đo. Sau đó, chỉ cần trừ hai mốc thời gian để ra được thời gian đã trôi qua:

import time

start = time.time()
# đoạn mã bạn muốn đo thời gian...
end = time.time()
print(end - start)  # thời gian tính bằng giây

Sử dụng timeit.default_timer() trong Python

Hàm default_timer() tự động chọn đồng hồ đo thời gian tối ưu nhất cho nền tảng và phiên bản Python của bạn. Đây là phương pháp được khuyến nghị để đảm bảo độ chính xác cao.

from timeit import default_timer as timer

start = timer()
# đoạn mã bạn muốn đo thời gian...
end = timer()
print(end - start)  # thời gian tính bằng giây

Dùng timeit từ dòng lệnh

timeit là mô-đun chuẩn cho phép bạn đo thời gian chạy của các đoạn mã nhỏ một cách đơn giản. Bạn có thể sử dụng nó từ dòng lệnh như sau:

Bài viết này được đăng tại [free tuts .net]

python -m timeit '"-".join(str(n) for n in range(100))'

Kết quả sẽ có dạng:

50000 loops, best of 5: 7.83 usec per loop

Nếu muốn giới hạn số lần lặp, bạn có thể thêm tùy chọn -n:

python -m timeit -n 100 '"-".join(str(n) for n in range(100))'

Sử dụng timeit trong mã Python

Bạn có thể sử dụng timeit trong mã của mình. Chỉ cần truyền vào một hàm (có thể là biểu thức lambda) để đo thời gian chạy:

import timeit

timeit.timeit(lambda: "-".join(map(str, range(100))), number=1000)

Sử dụng timeit trong Jupyter Notebook

Trong Jupyter Notebook, bạn có thể dùng lệnh ma thuật %timeit để đo thời gian. Cú pháp này rất tiện lợi khi bạn muốn đo thời gian chạy ngay trong ô lệnh:

# Jupyter cell
def do_something():
    for i in range(100): i * i

%timeit -n 1000 do_something()

Kết quả sẽ có dạng:

2.26 µs ± 82.5 ns per loop (mean ± std. dev. of 7 runs, 1,000 loops each)

Sử dụng decorator để đo thời gian chạy hàm trong Python

Nếu muốn đo thời gian cho nhiều hàm khác nhau mà không phải viết lại các dòng mã đo thời gian, bạn có thể tạo một decorator để bao bọc các hàm này và tự động đo thời gian chạy.

from timeit import default_timer as timer

def timer_func(func):
    def wrapper(*args, **kwargs):
        t1 = timer()
        result = func(*args, **kwargs)
        t2 = timer()
        print(f'{func.__name__}() thực thi trong {(t2-t1):.6f}s')
        return result
    return wrapper

Sau đó, áp dụng decorator @timer_func vào bất kỳ hàm nào mà bạn muốn đo thời gian:

@timer_func
def do_something():
    for i in range(1000000): i * i

do_something()
# do_something() thực thi trong 0.030401s

Kết bài

Tóm lại, Python cung cấp nhiều cách để đo thời gian chạy của mã từ đơn giản như time.time() đến các cách phức tạp hơn với timeit và decorator. Hy vọng với hướng dẫn này, bạn có thể chọn cho mình phương pháp đo thời gian phù hợp nhất cho các nhu cầu phân tích và tối ưu hóa hiệu suất mã của mình.

Cùng chuyên mục:

Cách sao chép danh sách (List) trong Python

Cách sao chép danh sách (List) trong Python

Cách làm việc với Notion API trong Python

Cách làm việc với Notion API trong Python

Cách background của hình ảnh trong Python

Cách background của hình ảnh trong Python

Cách tự viết Context Manager trong Python

Cách tự viết Context Manager trong Python

Hướng dẫn LangChain bằng Python

Hướng dẫn LangChain bằng Python

Hướng dẫn chuyển đổi file Google Colab sang Markdown trong Python

Hướng dẫn chuyển đổi file Google Colab sang Markdown trong Python

Cách xóa một khóa (key) ra khỏi dictionary trong Python

Cách xóa một khóa (key) ra khỏi dictionary trong Python

Cách chia List thành các phần bằng nhau trong Python

Cách chia List thành các phần bằng nhau trong Python

Sử dụng câu lệnh raise from trong Python

Sử dụng câu lệnh raise from trong Python

Ngoại lệ tùy chỉnh trong Python

Ngoại lệ tùy chỉnh trong Python

Ngoại lệ Raise trong Python

Ngoại lệ Raise trong Python

Tìm hiểu về các ngoại lệ trong Python

Tìm hiểu về các ngoại lệ trong Python

Tìm hiểu về decorator dataclass trong Python

Tìm hiểu về decorator dataclass trong Python

Ví dụ sử dụng metaclass trong Python

Ví dụ sử dụng metaclass trong Python

Lớp Metaclass trong Python

Lớp Metaclass trong Python

Tìm hiểu về Class Type trong Python

Tìm hiểu về Class Type trong Python

Phương thức __new__ trong Python

Phương thức __new__ trong Python

Phân biệt Data Descriptor và Non-data Descriptor trong Python

Phân biệt Data Descriptor và Non-data Descriptor trong Python

Mô tả Descriptors trong Python

Mô tả Descriptors trong Python

Tìm hiểu về các lớp mixin trong Python

Tìm hiểu về các lớp mixin trong Python

Top