Skip to main content

An intelligent Python code quality analyzer with architectural guidance

Project description

pyscn - Python Code Quality Analyzer

PyPI Go License CI

pyscn is a code quality analyzer for Python vibe coders.

Building with Cursor, Claude, or ChatGPT? pyscn performs structural analysis to keep your codebase maintainable:

  • 🔍 CFG-based dead code detection – Find unreachable code after exhaustive if-elif-else chains
  • 📋 Clone detection with APTED + LSH – Identify refactoring opportunities with tree edit distance
  • 🔗 Coupling metrics (CBO) – Track architecture quality and module dependencies
  • 📊 Cyclomatic complexity analysis – Spot functions that need breaking down

100,000+ lines/sec • Built with Go + tree-sitter

Quick Start

# Run analysis without installation
uvx pyscn analyze .
# or
pipx run pyscn analyze .

Common Commands

pyscn analyze

Run comprehensive analysis with HTML report

pyscn analyze .                              # All analyses with HTML report
pyscn analyze --json .                       # Generate JSON report
pyscn analyze --select complexity .          # Only complexity analysis
pyscn analyze --select deps .                # Only dependency analysis
pyscn analyze --select complexity,deps,deadcode . # Multiple analyses

pyscn check

Fast CI-friendly quality gate

pyscn check .                      # Quick pass/fail check
pyscn check --max-complexity 15 .  # Custom thresholds

pyscn init

Create configuration file

pyscn init                         # Generate .pyscn.toml

💡 Run pyscn --help or pyscn <command> --help for complete options

Configuration

Create a .pyscn.toml file or add [tool.pyscn] to your pyproject.toml:

# .pyscn.toml
[complexity]
max_complexity = 15

[dead_code]
min_severity = "warning"

[output]
directory = "reports"

⚙️ Run pyscn init to generate a full configuration file with all available options

Installation

# Install with pipx (recommended)
pipx install pyscn

# Or run directly with uvx
uvx pyscn
Alternative installation methods

Build from source

git clone https://github.com/ludo-technologies/pyscn.git
cd pyscn
make build

Go install

go install github.com/ludo-technologies/pyscn/cmd/pyscn@latest

CI/CD Integration

# .github/workflows/code-quality.yml
name: Code Quality
on: [push, pull_request]

jobs:
  quality-check:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - run: pip install pyscn
      - name: Quick quality check
        run: pyscn check .
      - name: Generate detailed report
        run: pyscn analyze --json --select complexity,deadcode,deps src/
      - name: Upload report
        uses: actions/upload-artifact@v4
        with:
          name: code-quality-report
          path: .pyscn/reports/

Documentation

📚 Development GuideArchitectureTesting

License

MIT License — see LICENSE


Built with ❤️ using Go and tree-sitter

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyscn-0.6.0b1-py3-none-win_amd64.whl (4.9 MB view details)

Uploaded Python 3Windows x86-64

pyscn-0.6.0b1-py3-none-manylinux_2_17_x86_64.whl (4.7 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

pyscn-0.6.0b1-py3-none-macosx_11_0_arm64.whl (4.4 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

pyscn-0.6.0b1-py3-none-macosx_10_9_x86_64.whl (4.7 MB view details)

Uploaded Python 3macOS 10.9+ x86-64

File details

Details for the file pyscn-0.6.0b1-py3-none-win_amd64.whl.

File metadata

  • Download URL: pyscn-0.6.0b1-py3-none-win_amd64.whl
  • Upload date:
  • Size: 4.9 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyscn-0.6.0b1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 75ba62183523388d730923f74bba42873b2ab46ff5a373144603edfa6b18694e
MD5 a95173e11673835fac6497decfbaec34
BLAKE2b-256 bba15e56ce147ff9958c7187d579e2dce277789a1b47067333d1c4e6d54724c7

See more details on using hashes here.

File details

Details for the file pyscn-0.6.0b1-py3-none-manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for pyscn-0.6.0b1-py3-none-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 dc0fa20482c88b85cea200d61a7b33d55a562f5a3861d3d91305cefa2eec43a6
MD5 8d7ef2fae57cc394562520c58ee2f8cf
BLAKE2b-256 acb02d0c1dedde8b523ec6838985695d4c61877605c27bb0bdf4d0201de79df9

See more details on using hashes here.

File details

Details for the file pyscn-0.6.0b1-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyscn-0.6.0b1-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ab7be1afb0f1edcb0b7212cebe900fc194f9ed2a42bd9775039430ab4fba500e
MD5 84bc7314cb3f7337c6c0f45fe56c97c2
BLAKE2b-256 c9791f3b1fdbbcccc5f4acffc09aa279561c3e6021c612830387750f2408e9a2

See more details on using hashes here.

File details

Details for the file pyscn-0.6.0b1-py3-none-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for pyscn-0.6.0b1-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 68fcb3e49a748897175c78a34ed96688c03b408b932e8079ed610e3f77fe6a6d
MD5 fc560a320600d1871c072a25fad51d43
BLAKE2b-256 069962c6ed7ba176c39729bf0572c95326dfdda852db8f07ca29d4852af4b0ba

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page