Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/TobiEiss/go-textfsm
golang textfsm
https://github.com/TobiEiss/go-textfsm
golang textfsm
Last synced: 2 months ago
JSON representation
golang textfsm
- Host: GitHub
- URL: https://github.com/TobiEiss/go-textfsm
- Owner: TobiEiss
- License: mit
- Created: 2019-01-26T11:04:47.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2021-10-15T07:34:01.000Z (about 3 years ago)
- Last Synced: 2024-07-31T18:19:03.734Z (5 months ago)
- Topics: golang, textfsm
- Language: Go
- Size: 84 KB
- Stars: 16
- Watchers: 3
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# go-textfsm
[![Build Status](https://travis-ci.org/TobiEiss/go-textfsm.svg?branch=master)](https://travis-ci.org/TobiEiss/go-textfsm)
[![GolangCI](https://golangci.com/badges/github.com/TobiEiss/go-textfsm.svg)](https://golangci.com)This library is an golang implementation of [TextFSM](https://github.com/google/textfsm).
If you miss something (there are definitely something) create an issue!# getting started
Given is following source-file `source.txt`
```
18:42:41.321 PST Sun Feb 8 2009
```Goal is to extract several values with following template-file `template.txt`
```
Value Year (\d+)
Value MonthDay (\d+)
Value Month (\w+)
Value Timezone (\S+)
Value Time (..:..:..)Start
^${Time}.* ${Timezone} \w+ ${Month} ${MonthDay} ${Year} -> Record
```You can use the following code to
1. read source-file `source.txt`
2. read template-file `template.txt`
3. process this files
4. print out resultFolder-structure for the example is like this:
```
.
├── templates
├── example_template.txt
├── index
├── source.txt
├── main.go
```Here the `main.go`:
```go
package mainimport (
"log"
"path/filepath"
"runtime""github.com/TobiEiss/go-textfsm/pkg/ast"
"github.com/TobiEiss/go-textfsm/pkg/process"
"github.com/TobiEiss/go-textfsm/pkg/reader"
)var (
_, b, _, _ = runtime.Caller(0)
basepath = filepath.Dir(b)
)func main() {
// read template
filepath := basepath + "/templates/example_template.txt"
tmplCh := make(chan string)
go reader.ReadLineByLine(filepath, tmplCh)// read file
filepathSrc := basepath + "/source.txt"
srcCh := make(chan string)
go reader.ReadLineByLine(filepathSrc, srcCh)// create AST
ast, err := ast.CreateAST(tmplCh)
if err != nil {
// handle error
}// process ast
record := make(chan []interface{})
process, err := process.NewProcess(ast, record)
if err != nil {
// handle error
}
go process.Do(srcCh)// print record
for {
// get next row
row, ok := <-record
if !ok {
break
}log.Println(row)
}
}
```for [CliTable](https://github.com/google/textfsm/wiki/Cli-Table):
```go
package mainimport (
"fmt"
"github.com/TobiEiss/go-textfsm/pkg/cliTable"
"github.com/TobiEiss/go-textfsm/pkg/process"
"github.com/TobiEiss/go-textfsm/pkg/reader"
"log"
)func main() {
srcChan := make(chan string)T := cliTable.NewCliTable("/templates", "index")
// cliTable attributes/mataData for template lookup
attrs := map[string]string{
"Command": "show required",
"Platform": "arista_eos",
}
go reader.ReadLineByLine("source.txt", srcChan)
abstractStatementT, err := T.CreateAST(attrs)
if err != nil {
log.Fatal(err)
}record := make(chan []interface{})
process, err := process.NewProcess(abstractStatementT, record)
if err != nil {
log.Fatal(err)
}go process.Do(srcChan)
for {
row, ok := <-record
if !ok {
break
}fmt.Println(row)
}}
```Find more examples how to build template-files here: [TextFSM-Wiki](https://github.com/google/textfsm/wiki/TextFSM)