码迷,mamicode.com
首页 > 其他好文 > 详细

golang 文件导入数据追加sheet

时间:2018-05-24 11:52:47      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:UNC   file   xlsx   测试   写入   return   max   pre   数据   

func ReadXlsx(c []CmdbTest, SheetName string) error {
    //打开文件,如果文件不存在创建,存在就打开
    path := "./cmdb_test.xlsx"
    b, err := PathExists(path)
    if err != nil {
        fmt.Sprintln(err)
    }
    if !b {
        files := xlsx.NewFile()
        //第一次创建文件时创建sheet
        alert := []string{"项目名称", "测试接口名称", "测试参数", "测试条数", "总耗时", "评均耗时", "最大耗时", "最小耗时"}
        sheet, _ := files.AddSheet(SheetName)
        row := sheet.AddRow()
        for _, a := range alert {
            row.AddCell().SetString(a)
        }
        err := files.Save(path)
        if err != nil {
            fmt.Println("创建xlsx文件发生错误")
            return err
        }
    }
    file, err := xlsx.OpenFile(path)
    if err != nil {
        fmt.Println("打开xlsx文件发生异常")
        return err
    }
    //判断结构体sheetName是否存在。
    br, err := SheetExists(path, SheetName)
    if err != nil {
        fmt.Println(err)
        return err
    }
    if !br {
        //追加创建新sheet
        alert := []string{"项目名称", "测试接口名称", "测试参数", "测试条数", "总耗时", "评均耗时", "最大耗时", "最小耗时"}
        sheet, _ := file.AddSheet(SheetName)
        row := sheet.AddRow()
        for _, a := range alert {
            row.AddCell().SetString(a)
        }
        err := file.Save(path)
        if err != nil {
            fmt.Println(err)
            return err
        }
    }
    //数据录入
    first, _ := file.Sheet[SheetName]
    for _, v := range c {
        ls := []string{v.PMName, v.InterfaceName, v.Type, v.TestNumber, v.SumTime, v.MeanTime, v.MaxTime, v.MinTime}
        row := first.AddRow()
        for _, r := range ls {
            cell := row.AddCell()
            cell.Value = r
            err = file.Save(path)
            if err != nil {
                fmt.Println("写入信息发生异常,文件正在使用")
                return err
            }
        }
    }
    return nil
}

golang 文件导入数据追加sheet

标签:UNC   file   xlsx   测试   写入   return   max   pre   数据   

原文地址:https://www.cnblogs.com/craneboos/p/9081427.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!