golang sql 导出xlsx 文件

aside section._1OhGeD · · 1284 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

需要导出的sql 表

image.png

代码 需要用到 "github.com/360EntSecGroup-Skylar/excelize" 请自行下载

此代码只限制 A到Z列,只限于一个sheet,数据量太大 建议修改

func SQL2XLSX(autoField []string,fileName string){

  f:= excelize.NewFile()

//写入自定义字段
  for i:=0;i<len(autoField);i++{

      k:=strings.ToUpper(string(rune(97+i)))+"1"

      fmt.Println(k,autoField[i])

      f.SetCellValue("Sheet1", k, autoField[i])

}


  SQL:=grdsql.NewDb("site_theme")

  query:="SELECT theme_id,theme_des,option_A,option_B,option_C,option_D,correct_option from jijiu"

  defer SQL.Close()

  if rows,err:=SQL.Query(query);err==nil{

      cloumns, err:= rows.Columns()

      values:= make([]sql.RawBytes, len(cloumns))

      scanArgs:= make([]interface{}, len(values))

      for i:= range values{

        scanArgs[i] = &values[i]

}

      index:= 0 //写入xls的行数

      for rows.Next() {

        err= rows.Scan(scanArgs...)

        if err!= nil{

}

        var valuestring

        for i, col:= range values{

            if col== nil{

              value= "  "

            } else {

              value= string(col)

}

            k:= strings.ToUpper(string(rune(97+i))) + strconv.Itoa(index+2) //生成XLS列名

            fmt.Println(k)

            f.SetCellValue("Sheet1", k, value)

            fmt.Println(cloumns[i], ": ", value)

}

        index++

      }

      err= f.SaveAs(fileName)

      if err!= nil{

        fmt.Println(err)

}

}

}

func main(){
//自定义字段名称
tt:=[]string{"编号","描述","选项A","选项B","选项C","选项D","正确答案"}

SQL2XLSX(tt,"test.xlsx")


}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section._1OhGeD

查看原文:golang sql 导出xlsx 文件

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1284 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传