golang csv,xls,xlsx
要用到的包:
"golang.org/x/text/encoding/simplifiedchinese"
"golang.org/x/text/transform"
func Decode(s []byte) ([]byte, error) {
I := bytes.NewReader(s)
O := transform.NewReader(I, simplifiedchinese.GBK.NewDecoder())
d, e := ioutil.ReadAll(O)
if e != nil {
return nil, e
}
return d, nil
}
func ReadCsv(execlFileName string) {
ProBar.Exist = 0
ProBar.Sucess = 0
ProBar.Fail = 0
ProBar.Count = 0
var (
err error
sucess int64
fail int64
exist int64
errcontent string
OrderTime time.Time
tradedata []TradeData
)
cntb, err := ioutil.ReadFile(execlFileName)
ress, err := Decode(cntb)
if err != nil {
beego.Error("change is err", err.Error())
return
}
buffer := bytes.NewBuffer(ress)
bufferline := bytes.NewBuffer(ress)
var cols int
for {
s, err := bufferline.ReadString(byte('\n'))
if err != nil {
beego.Error("err", err)
break
} else {
linestr := strings.Split(s, ",")
if len(linestr) > 5 && len(linestr[1]) > 5 {
cols++
}
}
}
ProBar.TotalPro = int64((cols - 1) * 3)
var linenum int
for {
s, err := buffer.ReadString(byte('\n'))
if err != nil {
beego.Error("err", err)
break
} else {
if linenum > 0 {
linestr := strings.Split(s, ",")
if len(linestr) > 5 && len(linestr[1]) > 5 {
beego.Debug("linestr lenght:", len(linestr))
var (
trade TradeData
)
for i := 0; i < len(linestr); i++ {
str := linestr[i]
if strings.TrimSpace(str) != "" {
ProBar.CurrentPro++
// for i := 0; i < len(str); i++ {
if strings.TrimSpace(linestr[i]) != "" {
trimsrt := strings.TrimRight(strings.TrimLeft(linestr[i], `="`), `"`)
beego.Debug("str : i", i, trimsrt)
if i == 1 {
customercode, _ := strconv.ParseFloat(trimsrt, 64) //客户账号
trade.CustomerCode = int64(customercode) //客户账号
}
if i == 2 {
trade.CustomerName = trimsrt //账户名称
}
if i == 3 {
trade.SuccessOrderCode = trimsrt //成交单号
}
if i == 4 {
trade.CommodityCode = trimsrt //成交代码
}
if i == 5 {
trade.CommodityName = trimsrt //商品名称
}
if i == 6 {
switch trimsrt {
case "买":
trade.TradeType = 1 //交易类型(0-未知,1-买,2-卖)
break
case "卖":
trade.TradeType = 2 //交易类型(0-未知,1-买,2-卖)
break
default:
trade.TradeType = 0 //交易类型(0-未知,1-买,2-卖)
if trade.TradeType == 0 {
fail++
beego.Debug("Transaction type error : ", linestr[i])
errcontent = errcontent + strconv.Itoa(i) + "行买卖类型错误"
break
}
}
}
if i == 7 {
trade.OrderCode = trimsrt //委托单号
}
if i == 8 {
trancount, _ := strconv.ParseFloat(trimsrt, 64) //成交数量
trade.TranCount = int64(trancount)
}
if i == 9 {
trade.TranPrice, _ = strconv.ParseFloat(trimsrt, 64) //成交价格
}
if i == 10 {
trade.TranAmount, _ = strconv.ParseFloat(trimsrt, 64) //成交金额
}
if i == 11 {
tranuser, _ := strconv.ParseFloat(trimsrt, 64) //交易员
trade.TranUser = int64(tranuser) //交易员
}
if i == 12 {
loc, _ := time.LoadLocation("Local") //重要:获取时区
trade.TradeTime, err = time.ParseInLocation("2006-01-02 15:04:05", trimsrt, loc) //成交时间
if err != nil {
fail++
beego.Debug("TradeTime wrong time : ", trimsrt)
errcontent = errcontent + strconv.Itoa(i) + "行 时间格式错误"
break
}
}
if i == 13 {
trade.ProfitLoss, _ = strconv.ParseFloat(trimsrt, 64) //转让盈亏
}
if i == 14 {
trade.PoundAge, _ = strconv.ParseFloat(trimsrt, 64) //手续费
}
if i >= 15 && strings.TrimSpace(trimsrt) != "" {
if i == 15 {
trade.OrderPrice, _ = strconv.ParseFloat(trimsrt, 64) //订立价格
}
if i == 16 {
loc, _ := time.LoadLocation("Local")
OrderTime, err = time.ParseInLocation("2006-01-02 15:04:05", trimsrt, loc) //订立时间
trade.OrderTime = OrderTime.Unix()
if err != nil {
fail++
beego.Debug("TradeTime wrong time : ", trimsrt)
errcontent = errcontent + strconv.Itoa(i) + "行 时间格式错误"
break
}
}
}
}
}
}
beego.Debug("trade", linenum, trade)
checktime := trade.TradeTime.Format("2006-01-02") //登入的时间
IsExist := CheckIsTradeData(checktime)
if !IsExist {
tradedata = append(tradedata, trade)
sucess++
} else {
exist++
beego.Debug("Database duplicate data : ", trade)
errcontent = errcontent + strconv.Itoa(linenum) + "行 数据库重复"
}
}
}
time.Sleep(time.Millisecond * 0)
}
linenum++
}
if sucess > 0 {
var commitfail int64
sucess, commitfail = AddTradeData(tradedata, sucess)
if commitfail > 0 {
fail = 0
sucess = 0
commitfail = int64(cols - 1)
}
fail += commitfail
os.Remove(execlFileName) //删除文件
}
ProBar.Sucess = sucess
ProBar.Fail = fail
ProBar.Exist = exist
ProBar.Count = int64(cols - 1)
ProBar.ErrorContent = errcontent
ProBar.Status = false
ProBar.CurrentPro = ProBar.TotalPro
}
func ReadXls(excelFileName string) (res [][]string) {
xlFile, err := xls.Open(excelFileName, "utf-8")
if err == nil {
beego.Debug(excelFileName, " file data read...................")
for i := 0; i < xlFile.NumSheets(); i++ {
sheet := xlFile.GetSheet(i)
temp := make([][]string, sheet.MaxRow+1)
for k, row := range sheet.Rows {
data := make([]string, 0)
for _, col := range row.Cols {
if uint16(len(data)) <= col.LastCol() {
data = append(data, make([]string, col.LastCol()-uint16(len(data))+1)...)
}
str := col.String(xlFile)
for i := uint16(0); i < col.LastCol()-col.FirstCol()+1; i++ {
data[col.FirstCol()+i] = str[i]
}
}
temp[k] = data
}
res = append(res, temp...)
}
} else {
beego.Debug(err)
}
return res
}
func ReadXlsx(excelFileName string) (res [][]string) {
xlFile, err := xlsx.OpenFile(excelFileName)
if err == nil {
beego.Debug(excelFileName, " file data read...................")
for _, sheet := range xlFile.Sheets {
temp := make([][]string, len(sheet.Rows))
for k, row := range sheet.Rows {
var data []string
for _, cell := range row.Cells {
data = append(data, cell.Value)
}
temp[k] = data
}
res = append(res, temp...)
}
} else {
beego.Debug(err)
}
return res
}
golang csv,xls,xlsx的更多相关文章
- Android 导入导出CSV,xls文件 .
1 . http://www.bangchui.org/read.php?tid=62 2 .http://blog.csdn.net/xinzheng_wang/article/details/77 ...
- 用NPOI实现导入导出csv、xls、xlsx数据功能
用NPOI实现导入导出csv.xls.xlsx数据功能 直接上代码 首先定义一个接口 如果需要直接操作文件的话,就自己在封装一次 然后定义csv类的具体实现 这个需要引入命名空间LumenWo ...
- java读取excel文件(.xls,xlsx,csv)
前提,maven工程通过poi读写excel文件,需要在pom.xml中配置依赖关系: 在<dependencies>中添加如下代码 <dependency> <grou ...
- phpexcel读取excel的xls xlsx csv格式
我之前写过一篇PHP读取csv文件的内容 上代码index.php <?php /** * * @author XC * */ class Excel { public $currentShee ...
- 在Linux中CSV转换成XLSX
在linux中,把csv文件转换成excel表格(xlsx或者xls) $ echo -e 'surname,name,age\nCarlo,Smith,23\nJohn,Doe,46\nJane,D ...
- 在.xls;*.xlsx类型文件的导入(可以导入多条数据)
2018-11-28 17:36:35 需要jar包:poi-3.8-201203026.jar jsp页面: <LINK href="${basePath}plugins/upl ...
- POI读取excel工具类(xls,xlsx通用)
package com.boot.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileNotF ...
- py3 读入和写入csv,txt文件
import numpy as npimport pandas as pdimport time import datetimeimport csv http://pandas.pydata.org/ ...
- POI解析excel格式的文件(xls,xlsx)
先贴出所需的jar包: 1.poi-3.17-beta1.jar 2.poi-ooxml-3.17-beta1.jar 3.poi-ooxml-schemas-3.17-beta1.jar 4.com ...
随机推荐
- YTU 2335: 0-1背包问题
2335: 0-1背包问题 时间限制: 1 Sec 内存限制: 128 MB 提交: 15 解决: 12 题目描述 试设计一个用回溯法搜索子集空间树的函数.该函数的参数包括结点可行性判定函数和上界 ...
- Uva 10118 免费糖果
题目链接:https://uva.onlinejudge.org/external/101/10118.pdf 参考:http://www.cnblogs.com/kedebug/archive/20 ...
- python Flask restful框架
框架地址:https://github.com/flask-restful/flask-restful 文档:http://flask-restful.readthedocs.io/en/0.3.5/ ...
- 基于PowerShell 3.0的web接口测试
对于web接口测试,做一下总结. 接口测试总结 1. 接口url格式:http://www.xxx.com/a/bbb.html: 2. 接口url后面接的参数格式:“?参数名=参数值&参数名 ...
- Android Https
/** * HttpUrlConnection支持所有Https免验证,不建议使用 * * @throws KeyManagementException * @throws NoSuchAlgorit ...
- WPFの布局中Panel的选用
一.Canvas 这个容器能够对元素做准确的定位,但同时也是其创建的页面不够灵活. 二.StackPanel 最大的优点是:他会顺序的对他的子元素进行排列显示.(没有任何附加属性) 要注意的是:他有两 ...
- C#数组的排序(正序逆序)
C#数组的排序(正序逆序) 这种排序 超级简单的 ! using System; using System.Collections.Generic; using System.Linq; using ...
- acdream1197 Points In Cuboid
题目链接:http://acdream.info/problem?pid=1197 题意:给出一些点.每次给出一个长方体,问在长方体中的点的个数. 思路:kd-tree. const int N=11 ...
- ios runtime的相关知识
一.iOS runtime原理 对于runtime机制,在网上找到的资料大概就是怎么去用这些东西,以及查看runtime.h头文件中的实现,当然这确实是一种很好的学习方法,但是,其实我们还是不会知道r ...
- freebsd镜像作用和vmware服务开启
第一个是可以引导的光盘,只能引导系统,通常用于网络安装.基本没用.第二个是系统光盘的第一张.用这张就可以安装一个基本的系统.其他的软件,在系统安装完之后安装.第三个是系统盘的DVD版本.包括的软件比上 ...