Dự án Python
Trình tạo dự án Python có thể được sử dụng để tạo một thư viện hoặc ứng dụng Python hiện đại được cấu hình với các phương pháp hay nhất, được quản lý bằng UV, một lockfile và môi trường ảo duy nhất trong UV workspace, pytest để chạy các bài kiểm tra, và Ruff để phân tích tĩnh.
Cách sử dụng
Phần tiêu đề “Cách sử dụng”Tạo một Dự án Python
Phần tiêu đề “Tạo một Dự án Python”Bạn có thể tạo một dự án Python mới theo hai cách:
- Cài đặt Nx Console VSCode Plugin nếu bạn chưa cài đặt
- Mở Nx Console trong VSCode
- Nhấp
Generate (UI)trong phần "Common Nx Commands" - Tìm kiếm
@aws/nx-plugin - py#project - Điền các tham số bắt buộc
- Nhấp
Generate
pnpm nx g @aws/nx-plugin:py#projectyarn nx g @aws/nx-plugin:py#projectnpx nx g @aws/nx-plugin:py#projectbunx nx g @aws/nx-plugin:py#projectBạn cũng có thể thực hiện chạy thử để xem những tệp nào sẽ bị thay đổi
pnpm nx g @aws/nx-plugin:py#project --dry-runyarn nx g @aws/nx-plugin:py#project --dry-runnpx nx g @aws/nx-plugin:py#project --dry-runbunx nx g @aws/nx-plugin:py#project --dry-runTùy chọn
Phần tiêu đề “Tùy chọn”| Tham số | Kiểu | Mặc định | Mô tả |
|---|---|---|---|
| name Bắt buộc | string | - | Tên của dự án Python |
| directory | string | packages | Thư mục cha nơi dự án được đặt. |
| subDirectory | string | - | Thư mục con mà dự án được đặt trong đó. Mặc định đây là tên dự án. |
| projectType Bắt buộc | string | application | Dự án là ứng dụng hay thư viện |
| moduleName | string | - | Tên module Python |
Kết quả của Trình tạo
Phần tiêu đề “Kết quả của Trình tạo”Trình tạo sẽ tạo cấu trúc dự án sau trong thư mục <directory>/<name>:
Thư mục<module-name>
- __init__.py Khởi tạo module
Thư mụctests
- __init__.py Khởi tạo module
- conftest.py Cấu hình kiểm tra
- test_noop.py Bài kiểm tra placeholder
- project.json Cấu hình dự án và các target build
- pyproject.toml Tệp cấu hình đóng gói được sử dụng bởi UV
- .python-version Chứa phiên bản Python của dự án
Bạn cũng có thể nhận thấy các tệp sau được tạo/cập nhật trong thư mục gốc của workspace:
- pyproject.toml Cấu hình đóng gói cấp workspace cho UV
- .python-version Chứa phiên bản Python của workspace
- uv.lock Lockfile cho các phụ thuộc Python
Viết Mã nguồn Python
Phần tiêu đề “Viết Mã nguồn Python”Thêm mã nguồn Python của bạn vào thư mục <module-name>.
Import Mã Thư viện của bạn trong Các Dự án Khác
Phần tiêu đề “Import Mã Thư viện của bạn trong Các Dự án Khác”Sử dụng target add để thêm phụ thuộc vào một dự án Python.
Giả sử chúng ta đã tạo hai dự án python, my_app và my_lib. Chúng sẽ có tên dự án đầy đủ là my_scope.my_app và my_scope.my_lib, và theo mặc định sẽ có tên module là my_scope_my_app và my_scope_my_lib.
Để my_app phụ thuộc vào my_lib, chúng ta có thể chạy lệnh sau:
pnpm nx run my_scope.my_app:add my_scope.my_libyarn nx run my_scope.my_app:add my_scope.my_libnpx nx run my_scope.my_app:add my_scope.my_libbunx nx run my_scope.my_app:add my_scope.my_libSau đó bạn có thể import mã thư viện của mình:
from my_scope_my_lib.my_module import my_functionỞ trên, my_scope_my_lib là tên module cho thư viện, my_module tương ứng với tệp nguồn Python my_module.py, và my_function là một phương thức được định nghĩa trong tệp đó.
Phụ thuộc
Phần tiêu đề “Phụ thuộc”Để thêm phụ thuộc vào dự án của bạn, bạn có thể chạy target add trong dự án Python của mình, ví dụ:
pnpm nx run my_scope.my_library:add some-pip-packageyarn nx run my_scope.my_library:add some-pip-packagenpx nx run my_scope.my_library:add some-pip-packagebunx nx run my_scope.my_library:add some-pip-packageĐiều này sẽ thêm phụ thuộc vào tệp pyproject.toml của dự án và cập nhật uv.lock ở thư mục gốc.
Mã Runtime
Phần tiêu đề “Mã Runtime”Khi bạn sử dụng dự án Python của mình làm mã runtime (ví dụ như handler cho một hàm AWS lambda), bạn sẽ cần tạo một bundle của mã nguồn và tất cả các phụ thuộc của nó. Bạn có thể đạt được điều này bằng cách thêm một target như sau vào tệp project.json của bạn:
{ ... "targets": { ... "bundle": { "cache": true, "executor": "nx:run-commands", "outputs": ["{workspaceRoot}/dist/packages/my_library/bundle"], "options": { "commands": [ "uv export --frozen --no-dev --no-editable --project packages/my_library --package my_scope.my_library -o dist/packages/my_library/bundle/requirements.txt", "uv pip install -n --no-deps --no-installer-metadata --no-compile-bytecode --python-platform x86_64-manylinux2014 --python `uv python pin` --target dist/packages/my_library/bundle -r dist/packages/my_library/bundle/requirements.txt" ], "parallel": false }, "dependsOn": ["compile"] }, },}Build
Phần tiêu đề “Build”Dự án Python của bạn được cấu hình với target build (được định nghĩa trong project.json), mà bạn có thể chạy thông qua:
pnpm nx build <project-name>yarn nx build <project-name>npx nx build <project-name>bunx nx build <project-name>Trong đó <project-name> là tên đầy đủ của dự án của bạn.
Target build sẽ biên dịch, lint và kiểm tra dự án của bạn.
Kết quả build có thể được tìm thấy trong thư mục dist gốc trong workspace của bạn, bên trong một thư mục cho package và target của bạn, ví dụ dist/packages/<my-library>/build
Để build tất cả các dự án trong workspace của bạn, chạy:
pnpm nx run-many --target buildyarn nx run-many --target buildnpx nx run-many --target buildbunx nx run-many --target buildHoặc sử dụng lệnh viết tắt:
pnpm buildyarn buildnpm run buildbun buildKiểm tra
Phần tiêu đề “Kiểm tra”pytest được cấu hình để kiểm tra dự án của bạn.
Viết Các Bài Kiểm tra
Phần tiêu đề “Viết Các Bài Kiểm tra”Các bài kiểm tra nên được viết trong thư mục test trong dự án của bạn, trong các tệp python có tiền tố test_, ví dụ:
Thư mụcmy_library
- my_module.py
Thư mụctests
- test_my_module.py Các bài kiểm tra cho my_module.py
Các bài kiểm tra là các phương thức bắt đầu bằng test_ và thực hiện các assertion để xác minh kỳ vọng, ví dụ:
from my_library.my_module import say_hello
def test_say_hello(): assert say_hello("Darth Vader") == "Hello, Darth Vader!"Để biết thêm chi tiết về cách viết các bài kiểm tra, vui lòng tham khảo tài liệu pytest.
Chạy Các Bài Kiểm tra
Phần tiêu đề “Chạy Các Bài Kiểm tra”Các bài kiểm tra sẽ chạy như một phần của target build cho dự án của bạn, nhưng bạn cũng có thể chạy chúng riêng biệt bằng cách chạy target test:
pnpm nx test <project-name>yarn nx test <project-name>npx nx test <project-name>bunx nx test <project-name>Bạn có thể chạy một bài kiểm tra riêng lẻ hoặc một nhóm bài kiểm tra bằng cách sử dụng cờ -k, chỉ định tên của tệp kiểm tra hoặc phương thức:
pnpm nx test <project-name> -k 'test_say_hello'yarn nx test <project-name> -k 'test_say_hello'npx nx test <project-name> -k 'test_say_hello'bunx nx test <project-name> -k 'test_say_hello'Linting
Phần tiêu đề “Linting”Các dự án Python sử dụng Ruff để linting.
Chạy Linter
Phần tiêu đề “Chạy Linter”Để gọi linter để kiểm tra dự án của bạn, bạn có thể chạy target lint.
pnpm nx lint <project-name>yarn nx lint <project-name>npx nx lint <project-name>bunx nx lint <project-name>Sửa Các Vấn đề Lint
Phần tiêu đề “Sửa Các Vấn đề Lint”Phần lớn các vấn đề linting hoặc formatting có thể được sửa tự động. Bạn có thể yêu cầu Ruff sửa các vấn đề lint bằng cách chạy với tham số --configuration=fix.
pnpm nx lint <project-name> --configuration=fixyarn nx lint <project-name> --configuration=fixnpx nx lint <project-name> --configuration=fixbunx nx lint <project-name> --configuration=fixTương tự, nếu bạn muốn sửa tất cả các vấn đề lint trong tất cả các package trong workspace của mình, bạn có thể chạy:
pnpm nx run-many --target lint --all --configuration=fixyarn nx run-many --target lint --all --configuration=fixnpx nx run-many --target lint --all --configuration=fixbunx nx run-many --target lint --all --configuration=fixBỏ qua Các Vấn đề Lint
Phần tiêu đề “Bỏ qua Các Vấn đề Lint”Để tránh các vấn đề linting làm chậm bạn trong quá trình phát triển (đặc biệt nếu bạn có các vấn đề không thể tự động sửa trong dự án của mình), bạn có thể chạy build với cấu hình skip-lint:
pnpm nx run-many --target build --configuration=skip-lintyarn nx run-many --target build --configuration=skip-lintnpx nx run-many --target build --configuration=skip-lintbunx nx run-many --target build --configuration=skip-lintĐiều này vẫn sẽ chạy Ruff như một phần của build, nhưng target lint sẽ luôn được coi là thành công.