Tabiew is a lightweight TUI application that allows users to view and query tabular data files, such as CSV, Parquet, Arrow, and ...
- ⌨️ Vim-style keybindings
- 🛠️ SQL support
- 📊 Support for CSV, Parquet, JSON, JSONL, Arrow, FWF, and Sqlite
- 🔍 Fuzzy search
- 📝 Scripting support
- 🗂️ Multi-table functionality
For a guide on using Tabiew, including instructions on opening files, navigating tables, performing queries, and using inline queries, kindly visit the tutorial page.
| Key Combination | Functionality | 
|---|---|
| Enter | Open record sheet | 
| kor↑ | Move up | 
| jor↓ | Move down | 
| hor← | Scroll left | 
| lor→ | Scroll right | 
| e | Toggle Auto-Fit | 
| Page UporCtrl + b | Move one page up | 
| Page DownorCtrl + f | Move one page down | 
| HorShift + ← | Select previous tab | 
| LorShift + → | Select next tab | 
| Ctrl + u | Move up half a page | 
| Ctrl + d | Move down half a page | 
| Homeorg | Move to the first row | 
| EndorG | Move to the last row | 
| Ctrl + r | Reset the data frame | 
| q | Close tab / sheet | 
| : | Command Pallete | 
| / | Fuzzy Search | 
| Command | Example | Description | 
|---|---|---|
| Qorquery | Q SELECT * FROM df | Query the data in Structured Query Language(SQL). The table name is the file name without extension | 
| Sorselect | S price, area, bedrooms, parking | Query current data frame for columns/functions | 
| Forfilter | F price < 20000 AND bedrooms > 4 | Filter current data frame, keeping rows were the condition(s) match | 
| Oororder | O area | Sort current data frame by column(s) | 
| tabn | tabn SELECT * FORM user WHERE balance > 1000 | Create a new tab with the given query | 
| qorquit | q | Return to table from sheet view otherwise quit | 
| schema | schema | Show loaded data frame(s) alongside their path(s) | 
| reset | reset | Reset the table to the original data frame | 
| help | help | Show help menu | 
There are various ways to install Tabiew:
You can install from the official repositories using pacman:
pacman -S tabiewDownload the .deb package from the GitHub releases page and run:
sudo dpkg -i <path_to_package.deb>Download the .rpm package from the GitHub releases page and run:
sudo rpm -i <path_to_package.rpm>Installing Tabiew using Homebrew from Homebrew core:
brew update
brew install tabiewor tap:
brew install shshemi/tabiew/tabiewNote: Please be aware that installing Tabiew from the tap involves compiling it from the source, which may take some time to complete.
Installing Tabiew from Crates.io:
cargo install tabiewEnsure you have rustc version 1.80 (or higher) installed. Download the desired source version from the release page. Extract the downloaded file and navigate into the extracted directory. Then run the following command:
cargo build --release
cp ./target/release/tw <system_or_local_bin_path>Start Tabiew with tw
tw <path_to_csv(s)>To open TSV file(s), use:
tw <path_to_tsv(s)> --separator $'\t' --no-headerTo open parquet file(s), use:
tw <path_to_parquet(s)> -f parquetContributions are welcome! Please fork the repository and submit pull requests with your features and bug fixes.
This project is licensed under the MIT License - see the LICENSE file for details.