Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sourcery-ai/sourcery-analytics
`sourcery-analytics` is a command line tool and library for statically analyzing Python code quality.
https://github.com/sourcery-ai/sourcery-analytics
code-quality python
Last synced: about 2 months ago
JSON representation
`sourcery-analytics` is a command line tool and library for statically analyzing Python code quality.
- Host: GitHub
- URL: https://github.com/sourcery-ai/sourcery-analytics
- Owner: sourcery-ai
- Created: 2022-04-19T18:18:24.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-05-28T22:03:49.000Z (7 months ago)
- Last Synced: 2024-05-29T13:01:38.990Z (7 months ago)
- Topics: code-quality, python
- Language: Python
- Homepage: https://sourcery-analytics.sourcery.ai/
- Size: 9.57 MB
- Stars: 16
- Watchers: 4
- Forks: 0
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# Sourcery Analytics
![PyPI](https://img.shields.io/pypi/v/sourcery-analytics)
![build, test, and publish docs](https://github.com/sourcery-ai/sourcery-analytics/actions/workflows/on_push_main.yml/badge.svg)
![code style](https://img.shields.io/badge/code%20style-black-000000.svg)
![docs](https://img.shields.io/badge/docs-github.io-green.svg)---
`sourcery-analytics` is a command line tool and library for statically analyzing Python code quality.
Get started by installing using `pip`:
```shell
pip install sourcery-analytics
```This will install `sourcery-analytics` as a command-line tool.
To identify code quality issues:
```shell
sourcery-analytics assess path/to/file.py
```Example:
```shell
sourcery-analytics assess sourcery_analytics/metrics
``````
sourcery_analytics/metrics/cyclomatic_complexity.py:47: error: working_memory of cyclomatic_complexity is 34 exceeding threshold of 20
Found 1 errors.
```To analyze a single Python file, use the `analyze` subcommand:
```shell
sourcery-analytics analyze path/to/file.py
```Example:
```shell
sourcery-analytics analyze sourcery_analytics/analysis.py
``````
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━┓
┃ Method ┃ length ┃ cyclomatic_complexity ┃ cognitive_complexity ┃ working_memory ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━┩
│ sourcery_analytics.analysis.analyze │ 5 │ 1 │ 0 │ 8 │
│ sourcery_analytics.analysis.analyze_methods │ 4 │ 1 │ 1 │ 12 │
└─────────────────────────────────────────────┴────────┴───────────────────────┴──────────────────────┴────────────────┘
```Alternatively, import and run analysis using the library:
```python
from sourcery_analytics import analyze_methods
source = """
def cast_spell(self, spell):
if self.power < spell.power:
raise InsufficientPower
print(f"{self.name} cast {spell.name}!")
"""
analyze_methods(source)
# [{'method_qualname': '.cast_spell', 'method_length': 3, 'method_cyclomatic_complexity': 1, 'method_cognitive_complexity': 1, 'method_working_memory': 6}]
```For more, see the [docs](https://sourcery-analytics.sourcery.ai/).
### Repoanalysis.com
You can see how hundreds of top projects measure across different code quality metrics and see how your priojects compare at [repoanalysis.com](https://repoanalysis.com/)### Developed by Sourcery
Sourcery Analytics was originally developed by the team at [Sourcery](https://sourcery.ai/?utm_source=sourcery-analytics). Sourcery is an automated coding assistant to help Python developers review and improve their code while they work. Sourcery has a built in library of 100+ core rules and you can extend it further to create custom rules for any scenario.