Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fatih/color
Color package for Go (golang)
https://github.com/fatih/color
ansi color coloring go golang
Last synced: 5 days ago
JSON representation
Color package for Go (golang)
- Host: GitHub
- URL: https://github.com/fatih/color
- Owner: fatih
- License: mit
- Created: 2014-02-17T09:13:35.000Z (almost 11 years ago)
- Default Branch: main
- Last Pushed: 2024-12-09T11:15:58.000Z (about 2 months ago)
- Last Synced: 2025-01-04T12:48:33.800Z (21 days ago)
- Topics: ansi, color, coloring, go, golang
- Language: Go
- Homepage: https://pkg.go.dev/github.com/fatih/color
- Size: 1.98 MB
- Stars: 7,444
- Watchers: 52
- Forks: 623
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-go - fatih/color
- awesomeLibrary - color - Color package for Go (golang). (语言资源库 / go)
- awesome-ccamel - fatih/color - Color package for Go (golang) (Go)
- go-awesome - Color - color of command line text (Open source library / Command Line)
- awesome-x - color
- awesome-go - Color - line output in Go. (Command Line)
- awesome-go - color - Color package for Go (golang) - ★ 2745 (Command Line)
README
# color [![](https://github.com/fatih/color/workflows/build/badge.svg)](https://github.com/fatih/color/actions) [![PkgGoDev](https://pkg.go.dev/badge/github.com/fatih/color)](https://pkg.go.dev/github.com/fatih/color)
Color lets you use colorized outputs in terms of [ANSI Escape
Codes](http://en.wikipedia.org/wiki/ANSI_escape_code#Colors) in Go (Golang). It
has support for Windows too! The API can be used in several ways, pick one that
suits you.![Color](https://user-images.githubusercontent.com/438920/96832689-03b3e000-13f4-11eb-9803-46f4c4de3406.jpg)
## Install
```
go get github.com/fatih/color
```## Examples
### Standard colors
```go
// Print with default helper functions
color.Cyan("Prints text in cyan.")// A newline will be appended automatically
color.Blue("Prints %s in blue.", "text")// These are using the default foreground colors
color.Red("We have red")
color.Magenta("And many others ..")```
### RGB colors
If your terminal supports 24-bit colors, you can use RGB color codes.
```go
color.RGB(255, 128, 0).Println("foreground orange")
color.RGB(230, 42, 42).Println("foreground red")color.BgRGB(255, 128, 0).Println("background orange")
color.BgRGB(230, 42, 42).Println("background red")
```### Mix and reuse colors
```go
// Create a new color object
c := color.New(color.FgCyan).Add(color.Underline)
c.Println("Prints cyan text with an underline.")// Or just add them to New()
d := color.New(color.FgCyan, color.Bold)
d.Printf("This prints bold cyan %s\n", "too!.")// Mix up foreground and background colors, create new mixes!
red := color.New(color.FgRed)boldRed := red.Add(color.Bold)
boldRed.Println("This will print text in bold red.")whiteBackground := red.Add(color.BgWhite)
whiteBackground.Println("Red text with white background.")// Mix with RGB color codes
color.RGB(255, 128, 0).AddBgRGB(0, 0, 0).Println("orange with black background")color.BgRGB(255, 128, 0).AddRGB(255, 255, 255).Println("orange background with white foreground")
```### Use your own output (io.Writer)
```go
// Use your own io.Writer output
color.New(color.FgBlue).Fprintln(myWriter, "blue color!")blue := color.New(color.FgBlue)
blue.Fprint(writer, "This will print text in blue.")
```### Custom print functions (PrintFunc)
```go
// Create a custom print function for convenience
red := color.New(color.FgRed).PrintfFunc()
red("Warning")
red("Error: %s", err)// Mix up multiple attributes
notice := color.New(color.Bold, color.FgGreen).PrintlnFunc()
notice("Don't forget this...")
```### Custom fprint functions (FprintFunc)
```go
blue := color.New(color.FgBlue).FprintfFunc()
blue(myWriter, "important notice: %s", stars)// Mix up with multiple attributes
success := color.New(color.Bold, color.FgGreen).FprintlnFunc()
success(myWriter, "Don't forget this...")
```### Insert into noncolor strings (SprintFunc)
```go
// Create SprintXxx functions to mix strings with other non-colorized strings:
yellow := color.New(color.FgYellow).SprintFunc()
red := color.New(color.FgRed).SprintFunc()
fmt.Printf("This is a %s and this is %s.\n", yellow("warning"), red("error"))info := color.New(color.FgWhite, color.BgGreen).SprintFunc()
fmt.Printf("This %s rocks!\n", info("package"))// Use helper functions
fmt.Println("This", color.RedString("warning"), "should be not neglected.")
fmt.Printf("%v %v\n", color.GreenString("Info:"), "an important message.")// Windows supported too! Just don't forget to change the output to color.Output
fmt.Fprintf(color.Output, "Windows support: %s", color.GreenString("PASS"))
```### Plug into existing code
```go
// Use handy standard colors
color.Set(color.FgYellow)fmt.Println("Existing text will now be in yellow")
fmt.Printf("This one %s\n", "too")color.Unset() // Don't forget to unset
// You can mix up parameters
color.Set(color.FgMagenta, color.Bold)
defer color.Unset() // Use it in your functionfmt.Println("All text will now be bold magenta.")
```### Disable/Enable color
There might be a case where you want to explicitly disable/enable color output. the
`go-isatty` package will automatically disable color output for non-tty output streams
(for example if the output were piped directly to `less`).The `color` package also disables color output if the [`NO_COLOR`](https://no-color.org) environment
variable is set to a non-empty string.`Color` has support to disable/enable colors programmatically both globally and
for single color definitions. For example suppose you have a CLI app and a
`-no-color` bool flag. You can easily disable the color output with:```go
var flagNoColor = flag.Bool("no-color", false, "Disable color output")if *flagNoColor {
color.NoColor = true // disables colorized output
}
```It also has support for single color definitions (local). You can
disable/enable color output on the fly:```go
c := color.New(color.FgCyan)
c.Println("Prints cyan text")c.DisableColor()
c.Println("This is printed without any color")c.EnableColor()
c.Println("This prints again cyan...")
```## GitHub Actions
To output color in GitHub Actions (or other CI systems that support ANSI colors), make sure to set `color.NoColor = false` so that it bypasses the check for non-tty output streams.
## Credits
* [Fatih Arslan](https://github.com/fatih)
* Windows support via @mattn: [colorable](https://github.com/mattn/go-colorable)## License
The MIT License (MIT) - see [`LICENSE.md`](https://github.com/fatih/color/blob/master/LICENSE.md) for more details