一.Go_tool

This is a tool library for Golang.Dont't worry about not understant it!
All comment writes by English,Ahaha~~

Oh,I think some will be Chinese.

二.Usage

go get -u -v github.com/hunterhug/go_tool
go get -v github.com/hunterhug/go_image
go get -v github.com/hunterhug/go-hbase
go get -v gopkg.in/redis.v4
go get -v github.com/gocql/gocql
go get -v golang.org/x/net/context

中国防火某些库无法下载!!!

三.Include

1.Image 图像处理库 (image deal library)

package image

import (
    "testing"
)

func TestImage(t *testing.T) {

    // Scale a image file by cuting 100*100
    err := ThumbnailF2F("../data/image.png", "../data/image100-100.png", 100, 100)
    if err != nil {
        t.Error("Test ThumbnailF2F:" + err.Error())
    }

    // Scale a image file by cuting width:200 (Equal scaling)
    err = ScaleF2F("../data/image.png", "../data/image200.png", 200)
    if err != nil {
        t.Error("Test ScaleF2F:" + err.Error())
    }

    // File Real name
    filename, err := RealImageName("../data/image.png")
    if err != nil {
        t.Error("Test RealImageName:" + err.Error())
    } else {
        t.Log("Test RealImageName::real filename" + filename)
    }
}

2.Spider 爬虫封装库 (spider library)

package spider

import (
    "testing"
    "fmt"
)

func TestSpider(t *testing.T) {

    // global log record
    //SetLogLevel("DEBUg")
    SetLogLevel("debug")
    // GLOBAL TIMEOUT
    SetGlobalTimeout(3)

    // a new spider without proxy
    // NewSpider(nil)
    proxy := "http://smart:smart2016@104.128.121.46:808"
    spiders,err := NewSpider(proxy)
    if err!=nil{
        panic(err)
    }
    // method can be get and post
    spiders.Method = "get"
    // wait times,can zero
    spiders.Wait = 2
    // which url fetch
    spiders.Url = "http://www.goole.com"

    // a new header,default ua, no refer
    spiders.NewHeader(nil, "www.google.com", nil)

    // go!fetch url --||
    body, err := spiders.Go()
    if err != nil {
        Log().Error(err)
    } else {
        // bytes get!
        fmt.Printf("%s", string(body))
    }

    Log().Debugf("%#v",spiders)

    // if filesize small than 500KB
    err = TooSortSizes(body, 500)

    Log().Error(err.Error())
}

3.Dbs 数据库封装库 (database library)

Mysql

package mysql

import (
    "testing"
)

/*

CREATE TABLE IF NOT EXISTS `51job_keyword` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `keyword` varchar(255) NOT NULL DEFAULT '',
  `address` varchar(255) NOT NULL DEFAULT '',
  `kind` varchar(255) NOT NULL DEFAULT '',
  `created` datetime DEFAULT NULL,
  `updated` datetime DEFAULT NULL,
  `time51` int(11) NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COMMENT='关键字表';

*/

func TestMysql(t *testing.T) {

    // mysql config
    config := MysqlConfig{
        Username: "root",
        Password: "smart2016",
        Ip:       "127.0.0.1",
        Port:     "3306",
        Dbname:   "51job",
    }

    // a new db connection
    db := New(config)

    // open connection
    db.Open()

    // create sql
    sql := `
  CREATE TABLE IF NOT EXISTS 51job.51job_keyword (
  id int(11) NOT NULL AUTO_INCREMENT,
  keyword varchar(255) NOT NULL DEFAULT '',
  address varchar(255) NOT NULL DEFAULT '',
  kind varchar(255) NOT NULL DEFAULT '',
  created datetime DEFAULT NULL,
  updated datetime DEFAULT NULL,
  time51 int(11) NOT NULL DEFAULT '0',
  PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COMMENT='关键字表';`

    // create
    inum, err := db.Create(sql)
    if err != nil {
        t.Error(err.Error())
    } else {
        t.Logf("create number:%d\n", inum)
    }

    // insert sql
    //'1', '教师', '潮州', '0', '2016-05-27 00:00:00', '2016-05-27 00:00:00', '204'
    sql = "INSERT INTO `51job_keyword`(`keyword`,`address`,`kind`) values(?,?,?)"

    // insert
    num, err := db.Insert(sql, "PHP", "潮州", 0)
    if err != nil {
        t.Error(err.Error())
    } else {
        t.Logf("insert number:%d\n", num)
    }

    // select sql
    sql = "SELECT * FROM 51job_keyword where address=? and kind=? limit ?;"

    // select
    result, err := db.Select(sql, "潮州", 0, 6)
    if err != nil {
        t.Error(err.Error())
    } else {
        // values
        for row, v := range result {
            t.Logf("%v:%#v\n", row, v)
        }
    }
}

Redis

package myredis

import (
    "testing"
)

func TestRedis(t *testing.T) {
    config := RedisConfig{}
    config.DB = 0
    config.Host = "127.0.0.1:6379"
    config.Password = "smart2016" // no password set ""

    client, err := NewRedis(config) // new redis client
    if err != nil {
        panic(err)
    }

    // set key==value
    err = client.Set("key", "value", 0)
    if err != nil {
        t.Error(err.Error())
    }

    // get key
    val, err := client.Get("key")
    if err != nil {
        panic(err)
    } else {
        t.Log("Redis value:" + val)
    }

    // push test,pust pool with b value
    num, err := client.Lpush("pool", "b")
    if err != nil {
        t.Error(err.Error())
    }

    // total length of list
    t.Log(num)

    // pushx test,will be error if not exist pool10
    num, err = client.Lpushx("pool10", "b")
    if err != nil {
        t.Error(err.Error())
    }
    t.Log(num)

    // len test
    t.Log(client.Llen("pool"))

    // pop test
    pops, e := client.Lpop("pool2")
    if e!=nil {
        t.Logf("%v,%v", pops, e)
    }

    // bpop test
    bpops, e := client.Blpop(0,"pool1","pool1")
    t.Logf("%#v,%v", bpops, e)

    //rpoplpush test POOL1 empty so will be redis.nil
    rpoplpush,e:=client.Rpoplpush("POOL1","pool1")
    t.Logf("%#v,%v", rpoplpush, e)

    //brpoplpush test POOL1 empty so will be redis.nil if timeout but zero set is wait a long time
    brpoplpush,e:=client.Brpoplpush("POOL1","pool1",15)
    t.Logf("%#v,%v", brpoplpush, e)
}

Cassandra

package cassandra

import (
    "github.com/gocql/gocql"
    "testing"
)

/* 
测试之前先填充一下cassandra语句
Before test:

create keyspace example with replication = { 'class' : 'SimpleStrategy', 'replication_factor' : 1 };
create table example.tweet(timeline text, id UUID, text text, PRIMARY KEY(id));
create index on example.tweet(timeline);
*/
func TestCdb(t *testing.T) {
    //先构造一个字符串数组连接
    // cassandra host
    host := []string{"192.168.11.74"}

    //指定cassandra keyspace,类似于mysql中的db
    // cassandra keyspace like mysql db
    keyword := "example"

    //连接
    // connect a cdb
    cdb := NewCdb(host, keyword)

    //构造插入语句
    // insert sql!
    insertsql := cdb.Query(`INSERT INTO tweet (timeline, id, text) VALUES (?, ?, ?)`,
        "me", gocql.TimeUUID(), "hello world")

    //执行,查看Exec方法,可知执行后已经关闭
    // exec a insert operation
    if err := insertsql.Exec(); err != nil {
        t.Fatal(err)
    }

    //构造查找语句
    // query sql
    querysql := cdb.Query(`SELECT "id", text FROM "tweet"`)

    //执行
    // done it !
    iter := querysql.Iter()

    //定义字节数组
    // id uuid in cassandra
    var id gocql.UUID
    var text string

    //循环取值,需要手工,无法再封装
    // take value just like that i can't wrap it again, and no need
    for iter.Scan(&id, &text) {
        t.Logf("Tweet:%v,%v\n", id, text)
    }

    //这个需要关闭
    // should be close
    if err := iter.Close(); err != nil {
        t.Logf("%v", err)
    }

}

Hbase

package myhbase

import (
    "github.com/hunterhug/go-hbase"
    "testing"
    "fmt"
    "time"
)

/*
before test,To do bellow

create_namespace 'hunterhug'
create 'hunterhug:info','colfamily',{SPLITALGO => 'HexStringSplit',NUMREGIONS => 40}
*/

func TestHbase(t1 *testing.T) {
    var (
        //格式化时间
        // Time format
        fs = "2006-01-02 15:04:05"

        //hbase配置
        //hbase config
        config = HbaseConfig{
            Zkport: "2181",//zk
            Zkquorum: "192.168.11.73",
        }
        //创建一个客户端
        // new client
        clients = New(config)
    )

    //打开客户端
    //open connection
    clients.Open()

    //放主键
    //set a rowkey
    rowkey := "rowkey"

    //命名空间
    //set namespace
    hbasenamespace := "hunterhug"

    //表名
    //set tablename
    hbasetable := "info"

    //列族
    //set colfamily
    hbasefamily := "colfamily"

    //set col
    hbasecol := "go"
    hbasecol1 := "die"

    //放值,第一列
    // put a value to  hunterhug:info colfamily:go
    put := hbase.CreateNewPut([]byte(rowkey))
    put.AddStringValue(hbasefamily, hbasecol, "value")
    _, err := clients.Client.Put(hbasenamespace + ":" + hbasetable, put)

    if err != nil {
        t1.Logf(err.Error())
    }

    //第二列
    // the same,put another value
    put.AddStringValue(hbasefamily, hbasecol1, "value1")
    _, err = clients.Client.Put(hbasenamespace + ":" + hbasetable, put)

    if err != nil {
        t1.Logf(err.Error())
    }

    //获取一行
    //get value by rowkey
    result, err := clients.GetResult(hbasenamespace + ":" + hbasetable, rowkey)
    if err != nil {
        t1.Logf(err.Error())
    }
    if v, exist := result.Columns[hbasefamily + ":" + hbasecol]; exist {
        fmt.Printf("found row:%v,v:%v\n",rowkey,v.Value.String())
    }

    //扫描
    // create a scan object,so scan can be close because client is inside in it
    scan := clients.Client.Scan(hbasenamespace + ":" + hbasetable)

    //过滤两列,只拿
    // just scan one col
    err = scan.AddString(hbasefamily + ":" + hbasecol)

    if err != nil {
        panic(err)
    }

    // no!we want two col
    err = scan.AddString(hbasefamily + ":" + hbasecol1)
    if err != nil {
        panic(err)
    }

    //过滤时间戳,只拿时间戳在这段范围的合数据
    // and we are just want before 720h's data
    var t = time.Now().Add(-1 * 720 * time.Hour * 1)

    fmt.Printf("Get Data which record before %v\n", t.Format(fs))

    // Time filter
    scan.SetTimeRangeFrom(t)

    var v1, v2 string

    //循环处理值
    // get scan value
    scan.Map(func(r *hbase.ResultRow) {
        // if value exist,v1!
        if v, exist := r.Columns[hbasefamily + ":" + hbasecol]; exist {
            v1 = v.Value.String()
        }
        if v, exist := r.Columns[hbasefamily + ":" + hbasecol1]; exist {
            v2 = v.Value.String()
        }
        // output
        fmt.Printf("row:%s\t  %s:%s \t %s:%s \t", r.Row.String(), hbasecol, v1, hbasecol1, v2)
    })
}

4.Log 日志库 (log library)

package mylog

import (
    "testing"
)

func TestLog(t *testing.T) {
    // log filename
    logger:=NewLog("test.log")

    // log level
    logger.SetLevel("error")

    logger.Println("1.println","11.println")
    logger.Error("error")
    logger.Debugf("%v","debug")
}

5.Util 文件/时间等杂项库 (some small library such as times and file)

package util

import (
    "testing"
)

func TestUtil(t *testing.T) {
    // test int to string
    i := 2
    if "2" == IS(i) {
        t.Log("Test IS:int to string")
    }

    // test string to int
    v, err := SI("e2")
    if err == nil && v == i {
        t.Log("Test SI:string to int")
    } else {
        t.Log("Test SI:" + err.Error())
    }

    // caller dir
    t.Log("Test CurDir:"+CurDir())

    // create dir
    err = MakeDir("../data")
    if err != nil {
        t.Log("Test MakeDir:" + err.Error())
    } else {
        t.Log("Test MakeDir:dir already exist")
    }

    // create dir by filename
    filename := "../data/testutil.txt"
    err = MakeDirByFile(filename)
    if err != nil {
        t.Log("Test MakeDirByFile:" + err.Error())
    } else {
        t.Log("Test MakeDirByFile: dir already exist")
    }

    // save bytes into file
    err = SaveToFile(filename, []byte("testutil"))
    if err != nil {
        t.Log("Test SaveToFile" + err.Error())
    }

    // read bytes from file
    filebytes, err := ReadfromFile(filename)
    if err != nil {
        t.Error("Test ReadfromFile:" + err.Error())
    } else {
        t.Log("Test ReadfromFile:" + string(filebytes))
    }

    // times format
    t.Log(TodayString(3))

    // file exist?
    t.Logf("%v",FileExist("../r.txt"))

    // find the go file in some dir
    filenames,err:=ListDir(`G:\smartdogo\src\github.com\hunterhug\go_tool`,"go")
    t.Logf("%v:%v",filenames,err)

    // devide a string list into severy string list
    stringlist:=[]string{"2","3","4","5","4"}
    num:=3
    result,err:=DevideStringList(stringlist,num)
    if err!=nil{
        t.Error(err)
    }else{
        t.Logf("%#v",result)
    }

    // now secord times from January 1, 1970 UTC.
    secord:=GetSecordTimes()
    t.Log(secord)

    // now date string by secord
    timestring:=GetSecord2DateTimes(secord)
    t.Log(timestring)

    // change back
    t.Log(GetDateTimes2Secord(timestring))
}

四.How to use

You all can read the test golang file.And I recomment use IDE pycharm which python language use,
can also install The Go plugin.

五.Author

一只尼玛

My website:http://www.lenggirl.com

My Twitter:https://twitter.com/hunterhug_

My Weibo:http://weibo.com/hunterhug

Updating...

Golang tool:include spider library,image library and some other db library such as mysql,redis,mogodb,hbase,cassandra的更多相关文章

  1. yum安装提示错误Thread/process failed: Thread died in Berkeley DB library

    问题描述: yum 安装更新提示 rpmdb: Thread/process failed: Thread died in Berkeley DB library 问题解决: 01.删除yum临时库文 ...

  2. 解决:Cannot load ocl.dll library(error code 126). The ocil.dll library may be missing from the system

           因为这两天在做将springboot 项目使用的数据库MySQL转换为Oracle数据库,所以在网上查找相关资料后开始使用 Convert-Mysql-to-Oracle4.0做转换: ...

  3. rpmdb: Thread/process 9180/139855524558592 failed: Thread died in Berkeley DB library

    使用yum安装出现问题:rpmdb: Thread/process 9180/139855524558592 failed: Thread died in Berkeley DB library 解决 ...

  4. rpmdb: Thread/process 10646/3086534416 failed: Thread died in Berkeley DB library

    明明用rpm查看包存在,但删除的时候进程就停住了.后来出现以下错误:rpmdb: Thread/process 10646/3086534416 failed: Thread died in Berk ...

  5. Library Publication 时遇到 "more than one library with package name" 错误的解决方法

    Library Publication 是 Gradle 在0.9.0 时增加的一个新特性,它的作用是让Lib也能发布不同的版本 在这之前,Lib只能发布release版本,你的项目中依赖的所有Lib ...

  6. 引用library之——带有自定义属性的自定义控件的library包

    一般来讲,当自定义一个控件Panel并且此控件有自定义属性时(例如:panel:closedHandle="@drawable/foot_bar_right"),xml中需要定义此 ...

  7. yum源出问题,rpmdb: BDB0113 Thread/process 17276/140338032428864 failed: BDB1507 Thread died in Berkeley DB library

    yum源出问题 cd /var/lib/rpm rm -f *db.* rpm --rebuilddb 重构了之后就可以用了

  8. 非关系型数据库----MongoDB

    一.什么是MongoDB? MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提 ...

  9. Prometheus基础

    监控系统作用 监控系统主要用于保证所有业务系统正常运行, 和业务的瓶颈监控. 需要周期性采集和探测. 采集的详情 采集: 采集器, 被监控端, 监控代理, 应用程序自带仪表盘, 黑盒监控, SNMP. ...

随机推荐

  1. jdk1.8 ThreadPoolExecutor实现机制分析

    ThreadPoolExecutor几个重要的状态码字段 private static final int COUNT_BITS = Integer.SIZE - 3; private static ...

  2. ArrayList实现源码分析

    本文将以以下几个问题来探讨ArrayList的源码实现 1.ArrayList的大小是如何自动增加的 2.什么情况下你会使用ArrayList?什么时候你会选择LinkedList? 3.如何复制某个 ...

  3. QTimer太让人失望了,一秒触发一次事件都不准确。。

    今天做项目中,我用QTimer来模拟数据生成,在另外的设备上接受.另外设备上有时1秒读不到数据,查询原因很久,终于发现是QTimer的问题. 测试代码如下 有兴趣同学可以自己试试. t = new Q ...

  4. hdu 1518 拼正方形

    本题来自:http://acm.hdu.edu.cn/showproblem.php?pid=1518 题意:输入几个长度,判断能否拼成正方形. 以下部分参考了网友代码,终于ac啦. #include ...

  5. sqlserver允许远程连接的配置

    如果无法通过IP地址远程连接你服务器上的SQL Server服务器,可以参考下面的内容进行设置 在进行下述设置之前,应该确保你的网络已经安装设置完毕,服务器已经正常连接到网络中. 1.单击Window ...

  6. 转:HTTP 1.1与HTTP 1.0的比较

    原文地址:http://blog.csdn.net/elifefly/article/details/3964766 HTTP 1.1与HTTP 1.0的比较 一个WEB站点每天可能要接收到上百万的用 ...

  7. C# 零散知识 扩展方法 类型约束

    今天看到这么一段代码,我看下面调用了NotifyPropertyChanged定义了两个参数,但是调用的时候只写了一个参数.后来查了下,原来这个是扩展方法的用法, 就是说给T扩展了一个方法Notify ...

  8. iOS开发之UIImage等比缩放

    iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...

  9. C++语言-02-函数

    普通函数 C++是在C语言的基础上增加了面向对象特性的语言,是C语言的超集 C++中的普通函数与C语言中的普通函数具有类似的性质.请参照以下博客:C语言-04-函数 与类相关的函数 C是一种OOP语言 ...

  10. win7操作技巧

    Q : 打开文件夹默认最大化A :随便打开一个文件夹 鼠标移动到左上角 然后点击鼠标左键 选择“最大化” 后关闭 之后每次打开就是最大化了