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:
- Install the Nx Console VSCode Plugin if you haven't already
- Open the Nx Console in VSCode
- Click
Generate (UI)in the "Common Nx Commands" section - Search for
@aws/nx-plugin - py#project - Fill in the required parameters
- Click
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#projectYou can also perform a dry-run to see what files would be changed
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”| Parameter | Type | Default | Description |
|---|---|---|---|
| name Required | string | - | The name of the Python project |
| directory | string | packages | Parent directory where the project is placed. |
| projectType Required | string | application | Project type |
| moduleName | string | - | Python module name |
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
- hello.py Tệp nguồn Python mẫu
Thư mụctests
- __init__.py Khởi tạo module
- conftest.py Cấu hình kiểm tra
- test_hello.py Các bài kiểm tra mẫu
- 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.hello import say_helloỞ trên, my_scope_my_lib là tên module cho thư viện, hello tương ứng với tệp nguồn Python hello.py, và say_hello là một phương thức được định nghĩa trong hello.py
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 run <project-name>:buildyarn nx run <project-name>:buildnpx nx run <project-name>:buildbunx nx run <project-name>:buildTrong đó <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
Kiể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
- hello.py
Thư mụctest
- test_hello.py Các bài kiểm tra cho hello.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.hello 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 run <project-name>:testyarn nx run <project-name>:testnpx nx run <project-name>:testbunx nx run <project-name>:testBạ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 run <project-name>:test -k 'test_say_hello'yarn nx run <project-name>:test -k 'test_say_hello'npx nx run <project-name>:test -k 'test_say_hello'bunx nx run <project-name>:test -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 run <project-name>:lintyarn nx run <project-name>:lintnpx nx run <project-name>:lintbunx nx run <project-name>:lintSử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 run <project-name>:lint --configuration=fixyarn nx run <project-name>:lint --configuration=fixnpx nx run <project-name>:lint --configuration=fixbunx nx run <project-name>:lint --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=fix