Golang : Not able to grep log.Println() output
Problem:
You have a Golang program that uses log.Println()
to capture text output generated by your program and you want to pipe the output to grep
command. Mysteriously, it is not working as expected. What's going on?
Solution and notes:
The underlying code behind log.Println()
uses fmt.Sprintln()
(see https://golang.org/src/log/log.go?s=8792:8822#L284) while fmt.Println()
uses Fprintln()
function. (see https://golang.org/src/fmt/print.go?s=7388:7437#L246)
The difference is that Fprintln()
writes to io.Writer, while Sprintln()
does not.
io.Writer will pipe text output to grep
command via the Unix/Linux's |
.
It is ok to use log.Println()
if you expect the log messages to be short or one line. Do not use log.Println()
to capture text output if it is going to be long - such as HTML.
Run the code example below and try to grep
the lines with page
generated by log.Println()
versus fmt.Println()
. You will see the differences immediately.
package main
import (
"fmt"
"io/ioutil"
// "log"
"net/http"
"os"
)
func main() {
// http.Get() can handle gzipped data response
// automagically
resp, err := http.Get("https://golang.org")
if err != nil {
fmt.Println(err)
os.Exit(1)
}
defer resp.Body.Close()
htmlData, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
//log.Println(string(htmlData)) //<-- grep will not work
fmt.Println(string(htmlData)) //<-- grep will work
}
Output with fmt.Println()
:
./grepalog | grep "page"
<div id="page">
the content of this page is licensed under the
</div><!-- #page -->
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+6k Golang : Fibonacci number generator examples
+9.3k Golang : Generate 403 Forbidden to protect a page or prevent indexing by search engine
+8.4k Golang : Quadratic example
+6k Linux : How to fix Brother HL-1110 printing blank page problem
+18.5k Golang : How to get time from unix nano example
+22.7k Golang : Upload to S3 with official aws-sdk-go package
+11.8k Android Studio : Password input and reveal password example
+6.4k Golang : How to convert strange string to JSON with json.MarshalIndent
+8.8k Golang : Test a slice of integers for odd and even numbers
+8.3k Golang : Web(Javascript) to server-side websocket example
+16.1k Golang : delete and modify XML file content
+9k CodeIgniter : Load different view for mobile devices