tabby

package module
v1.1.1-color Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 6, 2021 License: MIT Imports: 5 Imported by: 7

README

Mentioned in Awesome Go

Tabby

A tiny library for super simple Golang tables

This is a fork of cheynewallace/tabby that uses juju/ansiterm instead of text/tabwriter as tab writer, so that colored text is supported in the output.

Get Tabby

go get github.com/AstroProfundis/tabby

Import Tabby

import "github.com/AstroProfundis/tabby"

Tabby is a tiny (around 70 lines of code) efficient libary for writing extremely simple table based terminal output in Golang.

Many table libraries out there are overly complicated and packed with features you don't need. If you simply want to write clean output to your terminal in table format with minimal effort, Tabby is for you.

Typical examples

  • Writing simple tables with heading and tab spaced columns
  • Writing log lines to the terminal with evenly spaced columns

Example With Heading

t := tabby.New()
t.AddHeader("NAME", "TITLE", "DEPARTMENT")
t.AddLine("John Smith", "Developer", "Engineering")
t.Print()

Output

NAME        TITLE      DEPARTMENT
----        -----      ----------
John Smith  Developer  Engineering

Example Without Heading

t := tabby.New()
t.AddLine("Info:", "WEB", "Success 200")
t.AddLine("Info:", "API", "Success 201")
t.AddLine("Error:", "DATABASE", "Connection Established")
t.Print()

Output

Info:   WEB       Success 200
Info:   API       Success 201
Error:  DATABASE  Connection Established

Example With Custom tabWriter

w := tabwriter.NewWriter(os.Stdout, 0, 0, 2, ' ', 0)
t := tabby.NewCustom(w)

Full Example

  • Default writer (os.Stdout) example:
package main

import "github.com/AstroProfundis/tabby"

func main() {
	t := tabby.New()
	t.AddHeader("NAME", "TITLE", "DEPARTMENT")
	t.AddLine("John Smith", "Developer", "Engineering")
	t.Print()
}
  • File writer example:
package main

import (
	"os"
	"text/tabwriter"

	"github.com/AstroProfundis/tabby"
)

func main() {
	fd, _ := os.OpenFile("test.txt", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0644)
	defer fd.Close()

	w := tabwriter.NewWriter(fd, 0, 0, 4, ' ', 0)
	t := tabby.NewCustom(w)
	t.AddHeader("NAME", "TITLE", "DEPARTMENT")
	t.AddLine("John Smith", "Developer", "Engineering")
	t.Print()
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Tabby

type Tabby struct {
	// contains filtered or unexported fields
}

Tabby is returned when New() is called.

func New

func New() *Tabby

New returns a new *ansiterm.TabWriter with default config

func NewCustom

func NewCustom(writer *ansiterm.TabWriter) *Tabby

NewCustom returns a new *Tabby with custom *ansiterm.TabWriter set

func (*Tabby) AddHeader

func (t *Tabby) AddHeader(args ...interface{})

AddHeader will write a new table line followed by a seperator

func (*Tabby) AddLine

func (t *Tabby) AddLine(args ...interface{})

AddLine will write a new table line

func (*Tabby) Print

func (t *Tabby) Print()

Print will write the table to the terminal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL