fix: log parser project

This commit is contained in:
Inanc Gumus
2019-04-26 00:26:36 +03:00
parent 60456e7756
commit 4ebe1ee22b

View File

@ -11,54 +11,63 @@ import (
"bufio" "bufio"
"fmt" "fmt"
"os" "os"
"sort"
"strconv" "strconv"
"strings" "strings"
) )
func main() { func main() {
var ( var (
// Stores the visits per unique domain sum map[string]int // total visits per domain
sum = make(map[string]int) domains []string // unique domain names
total int // total visits to all domains
// Stores the unique domain names for printing lines int // number of parsed lines (for the error messages)
domains []string
in = bufio.NewScanner(os.Stdin)
) )
sum = make(map[string]int)
// Scan the standard-in line by line // Scan the standard-in line by line
for line := 1; in.Scan(); line++ { in := bufio.NewScanner(os.Stdin)
for in.Scan() {
lines++
// Parse the fields // Parse the fields
fields := strings.Fields(in.Text()) fields := strings.Fields(in.Text())
if len(fields) != 2 { if len(fields) != 2 {
fmt.Printf("wrong input: %v (line #%d)\n", fields, line) fmt.Printf("wrong input: %v (line #%d)\n", fields, lines)
return return
} }
domain, visits := fields[0], fields[1]
// Collect the unique domains
if _, ok := sum[domain]; !ok {
domains = append(domains, domain)
}
// Sum the total visits per domain // Sum the total visits per domain
n, err := strconv.Atoi(visits) visits, err := strconv.Atoi(fields[1])
if n < 0 || err != nil { if visits < 0 || err != nil {
fmt.Printf("wrong input: %q (line #%d)\n", visits, line) fmt.Printf("wrong input: %q (line #%d)\n", fields[1], lines)
return return
} }
sum[domain] += n
name := fields[0]
// Collect the unique domains
if _, ok := sum[name]; !ok {
domains = append(domains, name)
}
// Keep track of total and per domain visits
total += visits
sum[name] += visits
} }
// Print the visits per domain // Print the visits per domain
var total int sort.Strings(domains)
for _, domain := range domains {
hits := sum[domain]
fmt.Printf("%-25s -> %d\n", domain, hits) fmt.Printf("%-30s %10s\n", "DOMAIN", "VISITS")
total += hits fmt.Println(strings.Repeat("-", 45))
for _, name := range domains {
visits := sum[name]
fmt.Printf("%-30s %10d\n", name, visits)
} }
// Print the total visits for all domains // Print the total visits for all domains
fmt.Printf("\n%-25s -> %d\n", "TOTAL", total) fmt.Printf("\n%-30s %10d\n", "TOTAL", total)
} }