Golang小例 命令行正则

package main
import (
    "bufio"
    "flag"
    "fmt"
    "os"
    "regexp"
)
func main() {
    defer func() {
        return
    }()
    data := flag.String("data","This is a example for test!","Type: Text!")
    length := flag.Bool("len",false,"Type: Bool!")
    r := flag.Bool("r","Type: Bool!")
    reString := flag.String("re","(a)","Type: Text!")
    findCount := flag.Int("count",-1,"Type: Int!")
    first := flag.Int("array",65537,"Type: Int!")
    second := flag.Int("resault","Type: Int!")
    pipe := flag.Bool("pipe","Type: Bool!"

    flag.Parse()

    if *pipe {
        reader := bufio.NewReader(os.Stdin)
        tempData,_,_ := reader.ReadLine()
        *data = string(tempData)
    }

    reg := regexp.MustCompile(*reString)
    resault := reg.FindAllStringSubmatch(*data,*findCount)
    if *length {
        fmt.Println(len(resault))
        return
    }

    if *r {
        for temp := 0; temp < len(resault); temp++ {
            if len(resault[temp]) != 1 {
                for rtemp := 1; rtemp < len(resault[temp]); rtemp++ {
                    fmt.Println(resault[temp][rtemp])
                }
            } else {
                fmt.Println("")
            }
        }
        return
    }


    if *first != 65537 {
        if *second != 65537 {
            fmt.Println(resault[*first][*second])
            return
        }

        fmt.Println(resault[*first])
        return
    }
    fmt.Println(resault)
    return
}

命令行正则筛选 使用命令:
-data 内容
-re 正则表达式
-count 匹配次数(默认-1全部匹配)
-array 数组选择
-resault 结果选择(1、表达式全部匹配 2、匹配括号内部)
-len
返回结果数目
-r
开启递归显示所有结果
-pipe
打开管道

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...