Metadata-Version: 2.2
Name: vl-csv-viewer
Version: 0.4.5
Summary: An ultrafast CSV viewer in terminals
Home-page: https://github.com/w9/vl-csv-viewer
Author: Contributors
Author-email: user@example.com
Project-URL: Bug Tracker, https://github.com/w9/vl-csv-viewer/issues
Project-URL: Source Code, https://github.com/w9/vl-csv-viewer
Keywords: csv,viewer,terminal,console,table,data,visualization
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: System Administrators
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Text Processing :: General
Classifier: Topic :: Utilities
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: argcomplete>=1.0.0
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: keywords
Dynamic: project-url
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# VL - View Large

An ultrafast CSV viewer in terminals. VL (View Large) is designed to handle very large CSV files efficiently by reading them line-by-line and rendering output immediately.

## Features

- **Streaming processing**: Reads CSV files line-by-line for ultrafast performance with large files
- **Adaptive column sizing**: Automatically calculates optimal column widths based on content
- **Minimal memory usage**: Designed to handle files of any size without loading them entirely into memory
- **Multiple border styles**: Choose from different table border styles (grid, simple, minimal, none)
- **Colored columns**: Display CSV data with alternating column colors for better readability
- **Customizable display**: Control header behavior, column widths, colors, and more
- **Comment filtering**: Ignore comment lines based on regex patterns (default: lines starting with #)

## Installation

```bash
# Create and activate a virtual environment (recommended)
python3 -m venv venv
source venv/bin/activate

# Install from the current directory
pip install -e .

# Or install directly
pip install .
```

## Shell Completion

VL supports shell completion for bash, zsh, and other shells via [argcomplete](https://github.com/kislyuk/argcomplete). This allows you to use tab completion for commands and options.

### Bash

To enable bash completion, add the following to your `~/.bashrc` file:

```bash
eval "$(register-python-argcomplete vl)"
eval "$(register-python-argcomplete vll)"
```

Or for global completion for all argcomplete-enabled commands:

```bash
eval "$(register-python-argcomplete --global)"
```

### Zsh

For zsh, you need to enable bash completion compatibility mode. Add the following to your `~/.zshrc`:

```zsh
autoload -U bashcompinit
bashcompinit
eval "$(register-python-argcomplete vl)"
eval "$(register-python-argcomplete vll)"
```

Or for global completion:

```zsh
autoload -U bashcompinit
bashcompinit
eval "$(register-python-argcomplete --global)"
```

## Usage

Basic usage:

```bash
# View a CSV file (uses comma delimiter by default for .csv files)
vl data.csv

# View a TSV or other file (uses tab delimiter by default for non-csv files)
vl data.tsv

# View a CSV file with pager (less -SR)
vll data.csv

# Specify a different delimiter
vl -d ';' data.csv

# Don't treat the first row as a header
vl --no-header data.csv

# Ignore comment lines (lines starting with #)
vl --ignore-comments data.csv

# Use a custom comment pattern (regex)
vl --ignore-comments --comment-pattern "^//.*" data.csv
```
The package provides two commands:
- `vl`: Directly outputs to the terminal
- `vll`: Pipes the output through `less -SR` pager (supports scrolling for large files)

Both commands support piped input:

```bash
# Pipe data from another command
cat data.csv | vl

# Pipe with options
cat data.csv | vl --colors --color-list bg_green,bg_white

# Pipe with pager
cat data.csv | vll
```
- `vll`: Pipes the output through `less -SR` pager (supports scrolling for large files)

### Display Options

```bash
# Use grid-style borders (default)
vl -s grid data.csv

# Use simple ASCII borders
vl -s simple data.csv

# Use minimal borders (only horizontal lines)
vl -s minimal data.csv

# No borders
vl -s none data.csv

# Set minimum column width
vl --min-width 10 data.csv

# Set maximum column width
vl --max-width 30 data.csv

# Enable colored columns
vl --colors data.csv

# Use custom colors (comma-separated list)
vl --colors --color-list red,green,blue,yellow data.csv

# Combine with border style
vl --colors --color-list bg_cyan,bg_white -s grid data.csv
```

Available colors:
- Text colors: black, red, green, yellow, blue, magenta, cyan, white
- Background colors: bg_black, bg_red, bg_green, bg_yellow, bg_blue, bg_magenta, bg_cyan, bg_white

## Performance

VL is optimized for performance with large CSV files:

1. It processes files line-by-line rather than loading the entire file into memory
2. It calculates initial column widths based on a preview of rows
3. Long cell content is truncated with ellipses when exceeding max width
4. Output is displayed immediately as data is processed

This makes VL suitable for working with CSV files of any size, even multi-gigabyte files that would be impractical to load into memory all at once.

## API Usage

You can also use VL programmatically in your Python scripts:

```python
from vl.formatter import view_csv

# View a CSV file with custom settings
view_csv(
    file_path='data.csv',
    delimiter=',',
    header=True,
    min_col_width=5,
    max_col_width=20,
    border_style='grid',
    use_colors=False,  # Set to True to enable colored columns
    column_colors=['bg_cyan', 'bg_white']  # Custom colors (optional)
)

# You can also use the CSVViewer class directly for more control
from vl.formatter import CSVViewer

viewer = CSVViewer(
    delimiter=',',
    header=True,
    min_col_width=5,
    max_col_width=20,
    border_style='grid',
    use_colors=True,  # Enable colored columns
    column_colors=['red', 'green', 'blue']  # Custom colors
)
viewer.view_csv('data.csv')
```

## Testing

The VL package includes a comprehensive test suite to ensure code quality and correctness.

### Running Tests

You can run the tests using Python's unittest framework:

```bash
# Run all tests
python -m unittest discover tests

# Run specific test file
python -m unittest tests/test_formatter.py

# Run specific test case
python -m unittest tests.test_formatter.TestCSVViewer
```

Alternatively, if you have pytest installed:

```bash
# Install pytest and coverage
pip install pytest pytest-cov

# Run tests with coverage report
pytest --cov=vl

# Generate HTML coverage report
pytest --cov=vl --cov-report=html
```

### Test Organization

- `tests/fixtures/` - Contains test data files
- `tests/test_formatter.py` - Tests for the formatter module
- `tests/test_cli.py` - Tests for the command-line interface

## License

MIT
