Graphical tool to search through a table of static data with the option of launching commands.
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.

alt text



Tabular is a GUI providing searching of a static table of data, with the option of launching commands from selected rows.

alt text

You provide the data via a CSV file, and configure the rules for viewing and searching the data via a properties file. There is also the option of launching commands from the data of a selected row.

alt text


  1. Ensure you have a version of a Java greater than or equal to Java 8.
  2. Download the latest version of the Tabular zip from here, and unzip into your directory of choice.
  3. Edit the table.csv and as per your requirements. Please see the examples and config reference below for some guidance.
  4. Run the jar file. Depending on your OS, just double click the jar and the application should launch. If this does not work, you can run: java -jar tabular.jar in the directory where the jar file is located.


There are 3 ways that Tabular can be used.

  1. To search across a table of data. See example.
  2. To search across a table of data, select a row, and run a command using data from that row. See example.
  3. To search across a table of data, select a row, search for an appropriate command, select a command to run. See example.

Configuration reference

General properties

property description comma delimited list of hotkey combinations which can then be used to restore Tabular from a minimized state. The format of these strings should be of the format used by the awt KeyStroke.getKeyStroke(String) method. See below for more info.
app.csv.delimiter allows you to specify the delimiter to use in the table.csv file. By default this is a comma ','
app.csv.escapedCharacterQuote allows you to specify a custom escape character when you want to include the delimiter in your cell text. By default this is a double quote ". See OpenCSV Documentation for more info. A comma separated list of column names to show in the table. Useful for specifying default column ordering. Can also be used to hide columns which you don't want to show, i.e. which might just be used to reference to from other cells.
app.column.abbreviations. Can be used to specify abbreviations for column names. e.g. app.column.abbreviations.Host=h Can make for more concise variable names.

Properties relevant when using commands

property description Can be used to dictate which columns to show in the command table, and in what order. Options are: Name & Description. Dictates the column to display in the main prompt box when a row is selected. The column to display in the main prompt box when a command is selected to run. Defaults to 'Name'.
app.close.console.on.command.finish Close Tabular once the command has finished running. Defaults to false. Defaults to false.

Command definitions

property description Human readable name for the command.
app.commmands..predicate The predicate to use for whether the command is available for a certain data row. The value can be any valid groovy code. Any cell values, System Variables, Environment Variables can be referenced using the ${myVar} notation. See examples below under app.commmands.startApplication.predicate which checks to see that the environment is not prod. If no predicate is specified, then the command will always be displayed.
app.commmands..command The command to run. Again any cell values, System Variables, Environment Variables can be referenced using the ${myVar} notation.
app.commmands..description Human readable description for the command.

Command definition examples in stock control
app.commmands.displayInStockControl.command=../stock-control-app.exe --show ${Id}
app.commmands.displayInStockControl.description=Opens up the selected item in the stock control application on website
app.commmands.displayInWebsite.command=firefox.exe '${Id}'
app.commmands.displayInWebsite.description=Open the item in a browser for low stock
app.commmands.orderLowStock.predicate=${NumInStock} <= 5
app.commmands.orderLowStock.command=./stock-control-app.exe --order ${Id}
app.commmands.orderLowStock.description=Places order for items which are low in stock

CSV file format

The CSV parsing is done using OpenCSV. Please see the documentation for more details. Variable substition can be used within the csv cell values. Variables should be specified with a preceding ${ and a trailing }. e.g. ${myVar}. Variables can be defined in the file. Other cell values in the same row can also be referenced simply by using the column name. Environment and System variables can also be referenced.

Per-user properties

One way of distributing Tabular amongst a team is to check-in the Tabular distribution, along with your table.csv and into a Version Control System e.g. Git/SVN. If users wish to configure any config overrides, they can create a '' and add any config overrides there. Be sure to add the file to the appropriate ignore file is not accidentally added to your VCS.


  • If you get an exception which looks like this: Exception in thread "main" java.lang.UnsupportedClassVersionError: org/tools4j/tabular/javafx/Main : Unsupported major.minor version 52.0, this probably means that you are using a version of Java < Java8. Check your Java version by running java -version.

Valid values for the '' property

You must use values accepted by javax.swing.Keystroke.getKeyStroke() method. You can find the docs here: Here are some examples:

control DELETE
alt shift X
alt shift released X
typed a

Capturing keystrokes

To 'capture' a keystroke combination to use within Tabular, you can run the jkeymaster 'key grabber' application. You can start it by running something like this on the command line:

java -cp lib/jkeymaster-1.2.jar com.tulskiy.keymaster.AWTTest

(jkeymaster jar is distributed with Tabular) If you're running on Windows, I've provided a key-grabber.bat file in the distribution which you can use. It will create a small window, with a small edit box which you can click into, and enter your keystrokes of choice. The keystrokes are printed out in the format required to configure Tabular's hotkey.