Multi-Source Data Processing Language
Project description
Norvelang
Multi-Source Data Processing Language
Features
- PEMDAS-compliant mathematical expressions
- String functions (upper, lower, len, contains, etc.)
- SQL-like pipelines for CSV, JSON, XML, SQLite, Excel
- Filtering and aggregation with grouping and joins
- Function support in show and where clauses
- Robust join handling with automatic column disambiguation
- Clean, extensible grammar
- CLI and Python API for interactive and programmatic use
Quick Start
data.csv | show name, age | where age > 30
Installation
uv venv
.venv\Scripts\activate
uv pip install -r .\requirements.txt
Usage
Command Line
# Run a sample file
python -m norve samples/math.nv
# Interactive REPL
python -m norve
# Use regular Lark parser (disable cython)
python -m norve samples/queries.nv --no-lark-cython
Python API
import norve
df = norve.execute_query('''data.csv | show name, age | limit 10''')
output = norve.execute_with_output('''data.csv | show name, age | limit 5''')
variables = {'my_table': 'users.csv'}
df = norve.execute_query('''let users = $my_table; $users | show name, age | limit 10''', variables=variables)
Directory Structure
norvelang/
├── norve/ # Core language implementation
│ ├── api/ # Python API
│ ├── ast/ # AST definitions
│ ├── error/ # Error handling
│ ├── interpreter/ # Pipeline execution
│ ├── transformer/ # AST transformation
│ ├── grammar.lark # Grammar definition
│ └── *.py # Core modules
├── publish/ # Create new release on Github and PyPI
├── samples/ # Example .nv files
├── sample_data/ # Test data files
├── tests/ # Unit tests
├── requirements.txt # Python dependencies
└── README.md # This file
Running Tests
cd tests
pytest -v
Sample Files
- math.nv: Math and function demos
- queries.nv, queries2.nv: Data processing examples
- data_sources.nv: Multi-format data
- errors.nv: Error handling
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
norve-0.1.1.tar.gz
(45.8 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
norve-0.1.1-py3-none-any.whl
(56.6 kB
view details)
File details
Details for the file norve-0.1.1.tar.gz.
File metadata
- Download URL: norve-0.1.1.tar.gz
- Upload date:
- Size: 45.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
721daac95a4454f7a40a58b8e6fd2f7e199c825a4d50a4ce51db7a88e059958c
|
|
| MD5 |
47746d78b96d984b2deee78c3b5418a4
|
|
| BLAKE2b-256 |
c91fd1e3b79e64db38d85aa1e001e11a2ba0471d41252eee4d000a56da854158
|
File details
Details for the file norve-0.1.1-py3-none-any.whl.
File metadata
- Download URL: norve-0.1.1-py3-none-any.whl
- Upload date:
- Size: 56.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
de93bc60a5549d2b33382617514fd43fd75d91cae4fd8b145f2115a625acfb9b
|
|
| MD5 |
36661e53f9abdd14975c6254321f289c
|
|
| BLAKE2b-256 |
bba62be6e9ca7eb4acec9320b244522a0fe47930e055cde86e0b073bc050ed1e
|