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.

Quick Start

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

Demo

https://github.com/user-attachments/assets/b8e52d90-2a8e-4b49-a7e5-8a9a46f6a672

Features

  • 🔍 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

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.8.0b1-py3-none-win_amd64.whl (4.9 MB view details)

Uploaded Python 3Windows x86-64

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

Uploaded Python 3manylinux: glibc 2.17+ x86-64

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

Uploaded Python 3macOS 11.0+ ARM64

pyscn-0.8.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.8.0b1-py3-none-win_amd64.whl.

File metadata

  • Download URL: pyscn-0.8.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.8.0b1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 69727faedfe333b29a23bc7298b02ab9b3a734fd85aab81bd992bad130383f6e
MD5 d7a1e01e7fc06124a57cd5bd63de55f2
BLAKE2b-256 ecf4749aca3ce30eeb71d070e89d5affce47dc383b024bc1d3c449c270e01ffe

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyscn-0.8.0b1-py3-none-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 ed6c03e3e7e7a0a557d5ff8ab0c26da99c5e7eb492cb203f0f02b00a2e7dbb48
MD5 536430b64072fe183971847dda860093
BLAKE2b-256 6df42ae551e6fe5ffbf1fdc822dfc627a7fea2632d9de9dbe0e2224f1ea2e6af

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyscn-0.8.0b1-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a4d5ddd5583d7fafc71a162ec68d5986c4d0ace0e0883a3af1d9ed8da7aed22e
MD5 d518c590b2594c150030071ad42edc8f
BLAKE2b-256 2ccb6ce9f0eab277491324d652174a2167befb3af9083feeae8c6d9774ba0108

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyscn-0.8.0b1-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 6c7138f818055edad2b1865b14b32f160ad2c625381438abd4dc2bbfe8b180ff
MD5 65c677efad7b9ef2f1f2bd055a74bd27
BLAKE2b-256 98466aa7e4b15c3eccad9738eaa874e158995ff699b955976f129fec5711db41

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