Skip to content
/ rvisidata Public
forked from paulklemm/rvisidata

Open any dataframe with visidata, a terminal-based spreadsheet application

License

Notifications You must be signed in to change notification settings

kofm/rvisidata

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rvisidata

The goal of rvisidata is to combine the power of Visidata, "A Swiss Army Chainsaw for Data", with R.

Installation

Visidata

You need to have Visidata installed. Please follow the official installation instructions provided here. If you already have python3 installed, the easiest way to install it is with pip3: pip3 install visidata.

To verify visidata is installed correctly, vd --version should print out the installed version.

Package

rvisidata can be installed with devtools from the official GitHub repo:

devtools::install_github('paulklemm/rvisidata')

Example

vd(iris)

How it Works

Internally, rvisidata writes the data frame as a csv file to a temporary folder and then loads it with visidata. Be therefore careful with very large data frames, because the writing process can take a while. It will delete the temporary file after the visidata session is closed.

I do not claim that this implementation is efficient or very elegant. But it works. Suggestions for making it faster are very welcome.

Options

This package supports integration with tmux.

The default behaviour is to open vd in a vertical pane above the current pane, if R is running in a tmux session.

To disable this, set:

options(rvisidata.cmd = FALSE)

If you're using the kitty terminal emulator (https://github.com/kovidgoyal/kitty), you can also open vd in a new tab within kitty, like this:

options(rvisidata.cmd = "kitty")

Advanced

To customize the way tmux or kitty set up this workspace (For example, opening vd in a new window rather than pane), you may supply your own shell script that invokes vd on your dataset.

Set:

options(rvisidata.cmd = "path/to/your/script")

Your script should take one argument, the filename to be opened.

For example, the following will open your dataframe in a vertical split above the R console window, and return focus back to R:

#!/bin/bash

filename=$1

tmux split-window -vb -p 70 "vd $filename" \; \
  select-pane -l

Limitations

Right now this tool only opens the data frame and discards any changes you make for two reasons: (1) you should do your data manipulation in R to have a reproducible analysis workflow and (2) it is easier to implement this way 😇.

Credits

Visidata is designed and developed by Saul Pwanson (official GitHub repository).

About

Open any dataframe with visidata, a terminal-based spreadsheet application

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • R 89.9%
  • Shell 10.1%