Go 读取xls文件 (shakinm/xlsReader/xls)

Go 读取xls文件 (shakinm/xlsReader/xls)

需求

近期开发需要解析xls、xlsx文件,因为excelize.OpenFile()打开xlsx文件可以,但是打开xlsx文件进行报错,所以我们这里只能另想办法,这里用到的扩展是 github.com/shakinm/xlsReader

下载
复制代码
go get github.com/shakinm/xlsReader
github地址
复制代码
https://github.com/shakinm/xlsReader
使用

我们可以根据以下给的test来分析

go 复制代码
func TestMiniFatWorkBook(t *testing.T) {
	wb, err := OpenFile("./../testfie/table.xls")

	if err != nil {
		t.Error("Error: ", err)
	}

	for i := 0; i <= wb.GetNumberSheets()-1; i++ {

		sheet, _ := wb.GetSheet(i)
		if sheet.GetRows() != nil {
			for _, row := range sheet.GetRows() {
				if row  != nil {

					for _, col := range row.GetCols() {

					//	fmt.Println(col.GetString())
						xf := col.GetXFIndex()
						//fmt.Println(xf)
						style := wb.GetXFbyIndex(xf)
						//fmt.Println(style)
						formatIdx := style.GetFormatIndex()
						//fmt.Println(formatIdx)
						format := wb.GetFormatByIndex(formatIdx)
						//fmt.Println(format)

						fstr := format.GetFormatString(col)
						fmt.Println(fstr)

					}
				}

			}
		}

	}
}

如果想返回第一个sheet 对应\[\]\[\]string

go 复制代码
"github.com/shakinm/xlsReader/xls"
go 复制代码
	wb, err := xls.OpenFile("./../testfie/table.xls")

	if err != nil {
		t.Error("Error: ", err)
	}

	var response [][]string
	sheet, _ := wb.GetSheet(0)
	if sheet.GetRows() != nil {
		response = make([][]string, len(sheet.GetRows()))
		for rowKey, row := range sheet.GetRows() {
			responseItem := make([]string, len(sheet.GetRows()))
			if row  != nil {
				for colKey, col := range row.GetCols() {
					colValue := col.GetString()
					responseItem[colKey] = colValue
				}
			}
			response[rowKey] = responseItem
		}
	}
	return response

当然我们也可以根据测试的案例返回不同的类型

go 复制代码
func TestGetWorkBook(t *testing.T) {

	wb, err := OpenFile("./../testfie/small_1_sheet.xls")

	if err != nil {
		t.Error("Error: ", err)
	}

	s, err := wb.GetSheet(0)
	cells, _ := s.GetRow(2)

	for k := range cells.cols {
		c, _ := cells.GetCol(k)

		formatIndex := wb.GetXFbyIndex(c.GetXFIndex())
		format := wb.GetFormatByIndex(formatIndex.GetFormatIndex())

		if err == nil {
			switch k {
			case 0:
				if c.GetInt64() != 3 {
					t.Error("Expected 3, got ", c.GetInt64())
				}
			case 1:
				if c.GetInt64() != 4 {
					t.Error("Expected 4, got ", c.GetInt64())
				}
			case 2:
				if c.GetFloat64() != 2.1 {
					t.Error("Expected 2.1, got ", c.GetFloat64())
				}
			case 3:
				if c.GetString() != "String 3" {
					t.Error("Expected 'String 3', got ", c.GetString())
				}
			case 4:
				if c.GetString() != "https://github.com/shakinm/xlsReader" {
					t.Error("Expected 'https://github.com/shakinm/xlsReader', got ", c.GetString())
				}
			case 5:
				if c.GetString() != "" {
					t.Error("Expected '', got ", c.GetString())
				}
			case 6:
				if c.GetString() != "" {
					t.Error("Expected '', got ", c.GetString())
				}
			case 7:
				if c.GetString() != "String 3" {
					t.Error("Expected 'String 3', got ", c.GetString())
				}
			case 8:
				if c.GetInt64() != 3 {
					t.Error("Expected 3, got ", c.GetInt64())
				}
			case 9: // bool
				if c.GetInt64() != 1 {
					t.Error("Expected 1, got ", c.GetInt64())
				}
				if c.GetString() != "TRUE" {
					t.Error("Expected 'TRUE', got ", c.GetString())
				}
			case 10: //date
				if format.GetFormatString(c) != "9/3/19" {
					t.Error("Expected '9/3/19', got ", format.GetFormatString(c))
				}
			case 11: //dateTime
				if format.GetFormatString(c) != "09/03/2019 13:12:59" {
					t.Error("Expected '09/03/2019 13:12:59', got ", format.GetFormatString(c))
				}
			case 12:
				if format.GetFormatString(c) != "55.00%" {
					t.Error("Expected '55.00%', got ", format.GetFormatString(c))
				}
			case 13:
				if format.GetFormatString(c) != "#DIV/0!" {
					t.Error("Expected '#DIV/0!', got ", format.GetFormatString(c))
				}
			}

		}
	}
}
相关推荐
风吹夏回6 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
Chengbei116 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1126 小时前
web-第一次课后作业
java·开发语言·idea
小熊Coding7 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋97 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本7 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
xiaoshuaishuai87 小时前
C# 内存管理与资源泄漏
开发语言·c#
lsx2024068 小时前
SVN 检出操作
开发语言
冬奇Lab8 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
鹏北海-RemHusband8 小时前
Go 语言进阶笔记 — 面向 JS/TS 前端开发者
笔记·golang