返回顶部
l

lsp-python

Python code quality checking and LSP integration using pylsp. Provides code diagnostics, completion, hover tips, and style analysis. Use when: checking Python errors/warnings, getting code completions, viewing function signatures, analyzing code quality, or fixing style issues.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.1.0
安全检测
已通过
1,324
下载量
0
收藏
概述
安装方式
版本历史

lsp-python

# LSP Python 技能 使用 Python Language Server Protocol (LSP) 进行代码质量检查和智能分析。 ## 快速开始 ### 1. 检查代码问题 ```bash # 单个文件 python3 scripts/lsp-service.py check <文件路径> # 批量检查 (推荐) python3 scripts/check_python.py <文件或目录> # 批量检查并自动修复 python3 scripts/check_python.py --auto-fix <文件或目录> ``` 示例: ```bash python3 scripts/lsp-service.py check my_script.py python3 scripts/check_python.py src/ python3 scripts/check_python.py --auto-fix src/ ``` ### 2. 获取代码补全 ```bash python3 scripts/lsp-service.py complete <文件> <行号> <字符位置> ``` ### 3. 查看符号信息 ```bash python3 scripts/lsp-service.py info <文件> <行号> <字符位置> ``` ## 依赖 - **Python 3.x** - **pylsp**: `pip install python-lsp-server` - **可选插件**: - `pip install python-lsp-server[all]` - 完整插件集 - `pip install pylsp-mypy` - 类型检查 - `pip install pylsp-black` - black 格式化 ## 核心功能 ### 代码诊断 (check) 检查 Python 文件中的错误和警告: - **pyflakes** - 代码错误检测 (未使用导入、未定义变量等) - **pycodestyle** - PEP8 风格检查 (格式、行长、空白等) 输出示例: ``` ⚠️ 第 3 行 [pyflakes]: 'os' imported but unused ⚠️ 第 6 行 [pycodestyle]: E302 expected 2 blank lines, found 1 ✅ 没有发现问题 ``` ### 代码补全 (complete) 获取指定位置的代码补全建议: ```bash python3 scripts/lsp-service.py complete script.py 5 10 ``` 输出: ``` 补全建议: • json (模块) • jsonpatch (模块) • requests (模块) ``` ### 悬停提示 (info) 查看函数签名、文档字符串等信息: ```bash python3 scripts/lsp-service.py info script.py 10 5 ``` ### 跳转定义 (goto) 查找符号的定义位置: ```bash python3 scripts/lsp-service.py goto script.py 15 10 ``` ## 自动修复代码问题 ### 清理未使用的导入 ```bash pip install autoflake autoflake --remove-all-unused-imports --in-place --recursive . ``` ### 格式化代码 ```bash pip install black black . ``` ### 完整修复流程 ```bash # 1. 备份 cp -r project/ project.backup # 2. 清理导入 autoflake --remove-all-unused-imports --in-place --recursive project/ # 3. 格式化 black project/ # 4. 验证 python3 scripts/lsp-service.py check project/main.py ``` ## 诊断严重性级别 | 级别 | 代码 | 含义 | |------|------|------| | ❌ | 1 | Error (错误) | | ⚠️ | 2 | Warning (警告) | | ℹ️ | 3 | Information (信息) | | 💡 | 4 | Hint (提示) | ## 常见问题代码 | 代码 | 含义 | 修复方法 | |------|------|----------| | E402 | 导入不在文件顶部 | 移动导入到文件开头 | | E501 | 行太长 (>79 字符) | 拆分长行或使用括号 | | W293 | 空行包含空白字符 | 删除行尾空格 | | E302 | 缺少空行 | 函数/类定义前加 2 个空行 | | E712 | 布尔比较风格 | `if x is True` → `if x` | ## 在 OpenClaw 中使用 ```bash exec: python3 /path/to/lsp-python/scripts/lsp-service.py check <file> ``` ## 批量检查项目 ```bash # 检查所有 Python 文件 find . -name "*.py" -exec python3 scripts/lsp-service.py check {} \; # 仅显示有问题的文件 for f in $(find . -name "*.py"); do result=$(python3 scripts/lsp-service.py check "$f" 2>&1) if ! echo "$result" | grep -q "✅ 没有发现问题"; then echo "=== $f ===" echo "$result" fi done ``` ## 参考资料 - **LSP 协议详解**: 见 `references/lsp-protocol.md` - **pylsp 配置**: 见 `references/pylsp-config.md` - **代码风格指南**: 见 `references/pep8-guide.md` ## 故障排除 ### pylsp 无法启动 ```bash # 检查安装 which pylsp pylsp --version # 重新安装 pip install --upgrade python-lsp-server ``` ### 检查超时 增加脚本中的 `LSP_TIMEOUT` 值 (默认 10 秒)。 ### 中文字符问题 确保文件使用 UTF-8 编码,脚本已设置 `ensure_ascii=False`。

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 lsp-python-1776287621 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 lsp-python-1776287621 技能

通过命令行安装

skillhub install lsp-python-1776287621

下载 Zip 包

⬇ 下载 lsp-python v1.1.0

文件大小: 13.98 KB | 发布时间: 2026-4-16 18:38

v1.1.0 最新 2026-4-16 18:38
Added batch check script (check_python.py) with auto-fix support and report generation

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部