Hướng dẫn black python
Ngay khi bạn mới làm quen với Python được vài tuần, mới biết tí for loop hay function, PEP8 từ đâu đó sẽ hiện ra. PEP8 là hướng dẫn viết code chuẩn Python, chứ không phải chuẩn C, Java, hay không có chuẩn nào cả. Nếu tự hoc code một mình, có khi giờ này bạn đã làm ra vài chục script, chạy ầm ầm mà vẫn chưa 1 lần nghe PEP8. Tiêu chuẩn code là thứ chỉ hiện ra rõ ràng, khi ta làm việc với người khác, chỉ sau vài function, sự mâu thuẫn về
style sẽ hiện ra ngay, và khi ông Chí Phèo không đồng ý với style của Bá Kiến, thì cả 2 phải lên phường và thống nhất dùng chuẩn chung mà làng Vũ Đại đặt ra - hay ở đây ta gọi là PEP8. PEP8 có thể xem chi tiết tại PEP0008 hay https://pep8.org/, tiêu chuẩn PEP8 được chấp nhận trên toàn trái đất, thậm chí
CIA, Google cũng chỉ sửa đi chút xíu, bởi nó là chuẩn hay, chuẩn tốt. Style vốn là một thứ dễ gây ra tranh cãi. Tôi thích kiểu Việt Nam dịu dàng, anh thích kiểu Pháp say đắm, ông kia thích kiểu Mỹ mạnh mẽ và hùng hục. Vậy ai là người sai? Cuộc tranh cãi về style viết code đã kéo dài suốt từ ngày lập trình xuất hiện, tới giờ vẫn chưa kết
thúc. Bởi đã là style, thì khó nói chuyện đúng sai. Thế rồi mọi cuộc chơi vui, cũng phải đến hồi kết. Một ngôn ngữ lập trình đơn giản xuất hiện với tên hai chữ Không có giải pháp nào để giải quyết 1 vấn đề tốt
hơn là làm cho nó biến mất. black là gìBlack là một câu lệnh cài bằng pip: https://github.com/psf/black/blob/master/black.py Code của black chỉ vọn vẹn 4000 dòng, sử dụng các tính năng mới nhất của Python như f-string, type annotation, asyncio... (vì thế nên yêu cầu Python3.6+ để chạy, mặc dù vẫn có thể format code 2.7) Dùng black để format code PythonVí dụ có 1 file foo.py
Nếu thành thạo PEP8, thấy ngay có 4 chỗ phải sửa ở đây: Chạy:
Đẹp, chuẩn, ngon! Không còn gì mong đợi thêm. black có nhiều option để chỉnh style cho phù hợp với tiêu chuẩn của bạn, hay dùng nhất là để set độ dài của 1 dòng, vốn là 79 ký tự theo chuẩn PEP8, thì black mặc định là 88:
Bạn có thể gọi Hành động của chúng taĐã đến lúc để
quên đi việc format code bằng tay, nhớ vài chục tiêu chuẩn của PEP8, format code hãy để cho đen (black) không vâu lo - việc này để đen không vâu lo. Thêm dòng này vào hay cài đặt text editor/IDE tự động chạy Thêm dòng sau vào CI để bắt quả tang thằng nào không dùng black: Black sẽ thông báo các file chưa chuẩn format:
Kết luậnHãy dùng |