| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650 | 
							- package api
 
- import (
 
- 	"encoding/json"
 
- 	"fmt"
 
- 	"math"
 
- 	"sort"
 
- 	"strconv"
 
- 	"strings"
 
- 	"time"
 
- 	"tmr-watch/http/handle/restful"
 
- 	"github.com/Anderson-Lu/gofasion/gofasion"
 
- 	"github.com/xormplus/xorm"
 
- )
 
- //包含报表模块前端需要的各种数据格式转换
 
- func praseReportform(sqlnamestr string, parammaps *gofasion.Fasion, tx *xorm.Session, checked string, offset, count, typea, mode int) (queryData map[string]interface{}, err error) {
 
- 	sql, p := restful.GetSqlByNameDBT(sqlnamestr, tx)
 
- 	s_params := make([]interface{}, 0)
 
- 	if sql != "" {
 
- 		paramslist := strings.Split(p, ",")
 
- 		if len(paramslist) > 0 && p != "" {
 
- 			for _, value := range paramslist {
 
- 				s_params = append(s_params, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 			}
 
- 		}
 
- 	}
 
- 	queryList, err := tx.SQL(sql, s_params...).Query().List()
 
- 	//############
 
- 	sql2, p2 := restful.GetSqlByNameDBT("getFeednameSort", tx)
 
- 	s_params2 := make([]interface{}, 0)
 
- 	if sql2 != "" {
 
- 		paramslist2 := strings.Split(p2, ",")
 
- 		if len(paramslist2) > 0 && p != "" {
 
- 			for _, value := range paramslist2 {
 
- 				s_params2 = append(s_params2, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 			}
 
- 		}
 
- 	}
 
- 	queryList2, err := tx.SQL(sql2, s_params2...).Query().List()
 
- 	var feednamesort []string
 
- 	var feedcodelist []string
 
- 	if len(queryList2) > 0 {
 
- 		for i := 0; i < len(queryList2); i++ {
 
- 			feednamesort = append(feednamesort, queryList2[i]["fname"].(string))
 
- 		}
 
- 	}
 
- 	// #########
 
- 	sql3, p3 := restful.GetSqlByNameDBT("getFeednameSort2", tx)
 
- 	s_params3 := make([]interface{}, 0)
 
- 	if sql3 != "" {
 
- 		paramslist3 := strings.Split(p3, ",")
 
- 		if len(paramslist3) > 0 && p != "" {
 
- 			for _, value := range paramslist3 {
 
- 				s_params3 = append(s_params3, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 			}
 
- 		}
 
- 	}
 
- 	// var queryList3 []map[string]interface{}
 
- 	feedDataList := make([]map[string]interface{}, 0)
 
- 	var feednamesort3 []string
 
- 	if sql3 != "" {
 
- 		queryList3, err := tx.SQL(sql3, s_params3...).Query().List()
 
- 		// fmt.Println()
 
- 		if err != nil {
 
- 			return nil, err
 
- 		}
 
- 		if len(queryList3) > 0 {
 
- 			for z := 0; z < len(queryList3); z++ {
 
- 				feednamesort3 = append(feednamesort3, queryList3[z]["feedname"].(string))
 
- 				feedcodelist = append(feedcodelist, queryList3[z]["feedcode"].(string))
 
- 			}
 
- 			feedDataList = append(feedDataList, queryList3...)
 
- 		}
 
- 	}
 
- 	if err != nil {
 
- 		return nil, err
 
- 	}
 
- 	// if len(queryList) == 0 {
 
- 	// 	return nil, nil
 
- 	// }
 
- 	temstr := ""
 
- 	//除特殊接口外,去接口名称的前10位做同一类型的转换
 
- 	switch sqlnamestr {
 
- 	case "getAccuracyAllHL", "getAccuracyAllQX", "getAccuracyAllJH", "getFeedEffMR", "getFeedEffHL", "getHomepageCB", "getAccuraa", "judgenurFTReportDetail":
 
- 		temstr = sqlnamestr
 
- 	default:
 
- 		temstr = sqlnamestr[:10]
 
- 	}
 
- 	// 根据名称选择不通类型的转换-(可自动扩展,不需要使用之前的)
 
- 	switch temstr {
 
- 	case "getAccurac", "getFeedEff":
 
- 		queryData, err = getAccuracy(queryList, "2006-01-02") // 不定参数
 
- 	case "getprocess":
 
- 		//queryData, err = getAccuracyV3v1(queryList)
 
- 		queryData, err = getAccuracyV3(queryList)
 
- 		// 统计分析 过程分析
 
- 		if sqlnamestr == "getprocessAnalysisTB" {
 
- 			quertDataList := queryData["list"]
 
- 			query := quertDataList.(map[string]interface{})
 
- 			querys, _ := GetprocessAnalysisTB(parammaps, tx, quertDataList, queryList)
 
- 			if len(querys) != 0 {
 
- 				query["data1"] = querys["WTime"]
 
- 				query["data2"] = querys["data2"]
 
- 				query["data3"] = querys["realWandT"]
 
- 				query["data5"] = querys["data5"]
 
- 			}
 
- 		}
 
- 	case "getHomepro":
 
- 		queryData, err = getAccuracyV3(queryList)
 
- 	case "getAccuracyAllHL", "getAccuracyAllQX", "getAccuracyAllJH", "getFeedEffMR", "getFeedEffHL", "getHomepageCB", "getAccuraa":
 
- 		queryData, err = getAccuracyV2(queryList) //固定维度 日期
 
- 	case "getMateria":
 
- 		sql1, p1 := restful.GetSqlByNameDBT(sqlnamestr+("sum"), tx)
 
- 		s_params1 := make([]interface{}, 0)
 
- 		if sql1 != "" {
 
- 			paramslist1 := strings.Split(p1, ",")
 
- 			if len(paramslist1) > 0 && p != "" {
 
- 				for _, value := range paramslist1 {
 
- 					s_params1 = append(s_params1, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 				}
 
- 			}
 
- 		}
 
- 		queryListSum, _ := tx.SQL(sql1, s_params1...).Query().List()
 
- 		if mode == 0 {
 
- 			queryData, err = getAccuracyV4(queryList, queryListSum, checked, feednamesort3, typea)
 
- 		} else {
 
- 			queryData, _ = getAccuracyV41(queryList, queryListSum, checked, feednamesort3, typea, feedDataList)
 
- 		}
 
- 		queryData["feedcode"] = feedcodelist
 
- 	case "getPriceAn":
 
- 		queryData, err = getAccuracyV5(queryList, typea)
 
- 	case "getJT1Accu":
 
- 		queryData, err = getAccuracyV6(queryList) //固定维度 牧场
 
- 	case "judgenurFT":
 
- 		queryData, err = getAccuracyV7(queryList)
 
- 	case "judgenurFTReportDetail":
 
- 		queryData, err = getAccuracyV8(queryList)
 
- 	case "downloadPl":
 
- 		var sql2, p2 string
 
- 		s_params2 := make([]interface{}, 0)
 
- 		if sqlnamestr == "downloadPlanSFJD" {
 
- 			sql2, p2 = restful.GetSqlByNameDBT("countfl", tx)
 
- 			//s_params1 := make([]interface{}, 0)
 
- 			if sql2 != "" {
 
- 				paramslist1 := strings.Split(p2, ",")
 
- 				if len(paramslist1) > 0 && p != "" {
 
- 					for _, value := range paramslist1 {
 
- 						s_params2 = append(s_params2, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 					}
 
- 				}
 
- 			}
 
- 		}
 
- 		queryList2, _ := tx.SQL(sql2, s_params2...).Query().List()
 
- 		var flleight string
 
- 		if len(queryList2) > 0 {
 
- 			flleight, _ = queryList2[0]["flcount"].(string)
 
- 			// fmt.Println(flleight)
 
- 		}
 
- 		flleightint, _ := strconv.Atoi(flleight)
 
- 		// getAccuracyV9English
 
- 		languageStatus := GetLanguageStatus()
 
- 		if languageStatus == "0" {
 
- 			if sqlnamestr == "downloadPlanTSLJD" {
 
- 				queryData, err = getAccuracyV9(queryList, sqlnamestr, flleightint, feednamesort3)
 
- 			} else {
 
- 				queryData, err = getAccuracyV9(queryList, sqlnamestr, flleightint, feednamesort) //投料简打、累加
 
- 			}
 
- 		} else {
 
- 			if sqlnamestr == "downloadPlanTSLJD" {
 
- 				queryData, err = getAccuracyV9English(queryList, sqlnamestr, flleightint, feednamesort3)
 
- 			} else {
 
- 				queryData, err = getAccuracyV9English(queryList, sqlnamestr, flleightint, feednamesort) //投料简打、累加
 
- 			}
 
- 		}
 
- 	default:
 
- 		queryData, err = nil, nil
 
- 	}
 
- 	return
 
- }
 
- func getAccuracyV9(queryList []map[string]interface{}, sqlnamestr string, flleightint int, feednamesort []string) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	mapc3 := make(map[string]interface{})
 
- 	data2 := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	mapc3["label"] = "车次"
 
- 	mapc3["prop"] = "projname"
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	mapc3["label"] = "TMR"
 
- 	mapc3["prop"] = "tmrtname"
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	//if sqlnamestr == "downloadPlanSFJD":
 
- 	//mapc3["label"] = "时间"
 
- 	//mapc3["prop"] = "plantime"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "班组"
 
- 	//mapc3["prop"] = "times"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "驾驶员"
 
- 	//mapc3["prop"] = "driver"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "日系数比例"
 
- 	//mapc3["prop"] = "rate"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "牛头数"
 
- 	//mapc3["prop"] = "feedpcount"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "配方模板"
 
- 	//mapc3["prop"] = "templetname"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//#######################################################################################
 
- 	mtem := make(map[interface{}]interface{})
 
- 	var stem, feedNames []string
 
- 	for _, feed := range feednamesort {
 
- 		feed = strings.ReplaceAll(feed, " ", "")
 
- 		mtem[feed] = struct{}{}
 
- 		// fmt.Println(feed)
 
- 		stem = append(stem, feed)
 
- 	}
 
- 	for i := 0; i < len(queryList); i++ { // 获取所有饲料种类
 
- 		// if _, ok := mtem[queryList[i]["fname"]]; ok {
 
- 		// 	continue
 
- 		// }
 
- 		// stem = append(stem, queryList[i]["fname"].(string))
 
- 		// mtem[queryList[i]["fname"]] = struct{}{}
 
- 		feedNames = append(feedNames, queryList[i]["fname"].(string))
 
- 	}
 
- 	sort.Strings(feedNames)
 
- 	for _, feed := range feedNames {
 
- 		if _, ok := mtem[feed]; ok {
 
- 			continue
 
- 		}
 
- 		// fmt.Println(feed)
 
- 		stem = append(stem, feed)
 
- 		mtem[feed] = struct{}{}
 
- 	}
 
- 	stemEnd := []string{}
 
- 	if sqlnamestr == "downloadPlanSFJD" {
 
- 		bb := stem[len(stem)-flleightint : len(stem) : len(stem)]
 
- 		//aa := stem[0 : len(stem)-flleightint : len(stem)]
 
- 		stemEnd = append(stemEnd, bb...)
 
- 		stemEnd = append(stemEnd, feednamesort...)
 
- 		//fmt.Println(stemEnd)
 
- 	} else {
 
- 		stemEnd = stem
 
- 	}
 
- 	//logging.Info("导出数据 ",stemEnd )
 
- 	for _, va := range stemEnd {
 
- 		mapc3["label"] = va
 
- 		mapc3["prop"] = va
 
- 		data1 = append(data1, mapc3)
 
- 		mapc3 = make(map[string]interface{})
 
- 	}
 
- 	if queryList[0]["sumlweight"] != nil {
 
- 		mapc3["label"] = "合计"
 
- 		mapc3["prop"] = "sumlweight"
 
- 	}
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	var tem interface{}
 
- 	mapc2 := make(map[string]interface{})
 
- 	for i := 0; i < len(queryList); i++ { // 获取所有饲料种类
 
- 		if i == 0 {
 
- 			tem = queryList[i]["projname"]
 
- 			mapc2 = queryList[i]
 
- 			if mapc2["sumlweight"] != nil {
 
- 				var sumlweight float64
 
- 				sumlweight, _ = strconv.ParseFloat(mapc2["sumlweight"].(string), 64)
 
- 				mapc2["sumlweight"] = sumlweight
 
- 			}
 
- 			for key := range mtem {
 
- 				mapc2[xorm.String(key)] = 0
 
- 			}
 
- 			// var lweight float64
 
- 			if queryList[i]["lweight"] != nil {
 
- 				// var error errors.Error
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		}
 
- 		if tem == queryList[i]["projname"] {
 
- 			// var lweight float64
 
- 			if queryList[i]["lweight"] != nil {
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		} else {
 
- 			data2 = append(data2, mapc2)
 
- 			tem = queryList[i]["projname"]
 
- 			mapc2 = queryList[i]
 
- 			if mapc2["sumlweight"] != nil {
 
- 				var sumlweight float64
 
- 				sumlweight, _ = strconv.ParseFloat(mapc2["sumlweight"].(string), 64)
 
- 				mapc2["sumlweight"] = sumlweight
 
- 			}
 
- 			for key := range mtem {
 
- 				mapc2[xorm.String(key)] = 0
 
- 			}
 
- 			if queryList[i]["lweight"] != nil {
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		}
 
- 	}
 
- 	data2 = append(data2, mapc2)
 
- 	chartData["data1"] = data1
 
- 	chartData["data2"] = data2
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV9English(queryList []map[string]interface{}, sqlnamestr string, flleightint int, feednamesort []string) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	mapc3 := make(map[string]interface{})
 
- 	data2 := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	mapc3["label"] = "Batch"
 
- 	mapc3["prop"] = "projname"
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	mapc3["label"] = "TMR"
 
- 	mapc3["prop"] = "tmrtname"
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	//if sqlnamestr == "downloadPlanSFJD":
 
- 	//mapc3["label"] = "时间"
 
- 	//mapc3["prop"] = "plantime"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "班组"
 
- 	//mapc3["prop"] = "times"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "驾驶员"
 
- 	//mapc3["prop"] = "driver"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "日系数比例"
 
- 	//mapc3["prop"] = "rate"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "牛头数"
 
- 	//mapc3["prop"] = "feedpcount"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//
 
- 	//mapc3["label"] = "配方模板"
 
- 	//mapc3["prop"] = "templetname"
 
- 	//data1 = append(data1, mapc3)
 
- 	//mapc3 = make(map[string]interface{})
 
- 	//#######################################################################################
 
- 	mtem := make(map[interface{}]interface{})
 
- 	var stem, feedNames []string
 
- 	for _, feed := range feednamesort {
 
- 		feed = strings.ReplaceAll(feed, " ", "")
 
- 		mtem[feed] = struct{}{}
 
- 		// fmt.Println(feed)
 
- 		stem = append(stem, feed)
 
- 	}
 
- 	for i := 0; i < len(queryList); i++ { // 获取所有饲料种类
 
- 		// if _, ok := mtem[queryList[i]["fname"]]; ok {
 
- 		// 	continue
 
- 		// }
 
- 		// stem = append(stem, queryList[i]["fname"].(string))
 
- 		// mtem[queryList[i]["fname"]] = struct{}{}
 
- 		feedNames = append(feedNames, queryList[i]["fname"].(string))
 
- 	}
 
- 	sort.Strings(feedNames)
 
- 	for _, feed := range feedNames {
 
- 		if _, ok := mtem[feed]; ok {
 
- 			continue
 
- 		}
 
- 		// fmt.Println(feed)
 
- 		stem = append(stem, feed)
 
- 		mtem[feed] = struct{}{}
 
- 	}
 
- 	stemEnd := []string{}
 
- 	if sqlnamestr == "downloadPlanSFJD" {
 
- 		bb := stem[len(stem)-flleightint : len(stem) : len(stem)]
 
- 		//aa := stem[0 : len(stem)-flleightint : len(stem)]
 
- 		stemEnd = append(stemEnd, bb...)
 
- 		stemEnd = append(stemEnd, feednamesort...)
 
- 		//fmt.Println(stemEnd)
 
- 	} else {
 
- 		stemEnd = stem
 
- 	}
 
- 	//logging.Info("导出数据 ",stemEnd )
 
- 	for _, va := range stemEnd {
 
- 		mapc3["label"] = va
 
- 		mapc3["prop"] = va
 
- 		data1 = append(data1, mapc3)
 
- 		mapc3 = make(map[string]interface{})
 
- 	}
 
- 	if queryList[0]["sumlweight"] != nil {
 
- 		mapc3["label"] = "Sum"
 
- 		mapc3["prop"] = "sumlweight"
 
- 	}
 
- 	data1 = append(data1, mapc3)
 
- 	mapc3 = make(map[string]interface{})
 
- 	var tem interface{}
 
- 	mapc2 := make(map[string]interface{})
 
- 	for i := 0; i < len(queryList); i++ { // 获取所有饲料种类
 
- 		if i == 0 {
 
- 			tem = queryList[i]["projname"]
 
- 			mapc2 = queryList[i]
 
- 			if mapc2["sumlweight"] != nil {
 
- 				var sumlweight float64
 
- 				sumlweight, _ = strconv.ParseFloat(mapc2["sumlweight"].(string), 64)
 
- 				mapc2["sumlweight"] = sumlweight
 
- 			}
 
- 			for key := range mtem {
 
- 				mapc2[xorm.String(key)] = 0
 
- 			}
 
- 			// var lweight float64
 
- 			if queryList[i]["lweight"] != nil {
 
- 				// var error errors.Error
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		}
 
- 		if tem == queryList[i]["projname"] {
 
- 			// var lweight float64
 
- 			if queryList[i]["lweight"] != nil {
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		} else {
 
- 			data2 = append(data2, mapc2)
 
- 			tem = queryList[i]["projname"]
 
- 			mapc2 = queryList[i]
 
- 			if mapc2["sumlweight"] != nil {
 
- 				var sumlweight float64
 
- 				sumlweight, _ = strconv.ParseFloat(mapc2["sumlweight"].(string), 64)
 
- 				mapc2["sumlweight"] = sumlweight
 
- 			}
 
- 			for key := range mtem {
 
- 				mapc2[xorm.String(key)] = 0
 
- 			}
 
- 			if queryList[i]["lweight"] != nil {
 
- 				lweight, err := strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 				if err == nil {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = lweight
 
- 				} else {
 
- 					mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 				}
 
- 			} else {
 
- 				mapc2[xorm.String(queryList[i]["fname"])] = queryList[i]["lweight"]
 
- 			}
 
- 		}
 
- 	}
 
- 	data2 = append(data2, mapc2)
 
- 	chartData["data1"] = data1
 
- 	chartData["data2"] = data2
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV8(queryList []map[string]interface{}) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	//list := make(map[string]interface{})
 
- 	data := []interface{}{}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		dry, _ := strconv.ParseFloat(queryList[i]["dry"].(string), 64)
 
- 		Hrate, _ := strconv.ParseFloat(queryList[i]["Hrate"].(string), 64)
 
- 		Srate, _ := strconv.ParseFloat(queryList[i]["Srate"].(string), 64)
 
- 		trans35f, _ := strconv.ParseFloat(queryList[i]["trans35f"].(string), 64)
 
- 		jcrate, _ := strconv.ParseFloat(queryList[i]["jcrate"].(string), 64)
 
- 		uprice, _ := strconv.ParseFloat(queryList[i]["uprice"].(string), 64)
 
- 		kprice, _ := strconv.ParseFloat(queryList[i]["dry"].(string), 64)
 
- 		adf, _ := strconv.ParseFloat(queryList[i]["adf"].(string), 64)
 
- 		ca, _ := strconv.ParseFloat(queryList[i]["ca"].(string), 64)
 
- 		cdry, _ := strconv.ParseFloat(queryList[i]["cdry"].(string), 64)
 
- 		cad, _ := strconv.ParseFloat(queryList[i]["cad"].(string), 64)
 
- 		cndf, _ := strconv.ParseFloat(queryList[i]["cndf"].(string), 64)
 
- 		cp, _ := strconv.ParseFloat(queryList[i]["cp"].(string), 64)
 
- 		cpd, _ := strconv.ParseFloat(queryList[i]["cpd"].(string), 64)
 
- 		fat, _ := strconv.ParseFloat(queryList[i]["fat"].(string), 64)
 
- 		ndf, _ := strconv.ParseFloat(queryList[i]["ndf"].(string), 64)
 
- 		nm, _ := strconv.ParseFloat(queryList[i]["nm"].(string), 64)
 
- 		nmd, _ := strconv.ParseFloat(queryList[i]["nmd"].(string), 64)
 
- 		nuint, _ := strconv.ParseFloat(queryList[i]["nuint"].(string), 64)
 
- 		p, _ := strconv.ParseFloat(queryList[i]["p"].(string), 64)
 
- 		pd, _ := strconv.ParseFloat(queryList[i]["pd"].(string), 64)
 
- 		starch, _ := strconv.ParseFloat(queryList[i]["starch"].(string), 64)
 
- 		trans4f, _ := strconv.ParseFloat(queryList[i]["trans4f"].(string), 64)
 
- 		list := make(map[string]interface{})
 
- 		list["ft"] = dry
 
- 		list["index"] = "干物质(kg)"
 
- 		list["tmr"] = TransFloat(dry * Hrate)
 
- 		list["cyl"] = TransFloat(dry * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = jcrate
 
- 		list["index"] = "粗精比(%)"
 
- 		list["tmr"] = TransFloat(jcrate * Hrate)
 
- 		list["cyl"] = TransFloat(jcrate * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = uprice
 
- 		list["index"] = "日粮成本(元)"
 
- 		list["tmr"] = TransFloat(uprice * Hrate)
 
- 		list["cyl"] = TransFloat(uprice * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = kprice
 
- 		list["index"] = "公斤奶成本"
 
- 		list["tmr"] = TransFloat(kprice * Hrate)
 
- 		list["cyl"] = TransFloat(kprice * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = cdry
 
- 		list["index"] = "粗料中的干物质"
 
- 		list["tmr"] = TransFloat(cdry * Hrate)
 
- 		list["cyl"] = TransFloat(cdry * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = nm
 
- 		list["index"] = " 产奶净能(MJ)"
 
- 		list["tmr"] = TransFloat(nm * Hrate)
 
- 		list["cyl"] = TransFloat(nm * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = nuint
 
- 		list["index"] = "奶牛能量单位(NND)"
 
- 		list["tmr"] = TransFloat(nuint * Hrate)
 
- 		list["cyl"] = TransFloat(nuint * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = cp
 
- 		list["index"] = "粗蛋白(g)"
 
- 		list["tmr"] = TransFloat(cp * Hrate)
 
- 		list["cyl"] = TransFloat(cp * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = cpd
 
- 		list["index"] = "粗蛋白(%DM)"
 
- 		list["tmr"] = TransFloat(cpd * Hrate)
 
- 		list["cyl"] = TransFloat(cpd * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = ca
 
- 		list["index"] = "钙(g)"
 
- 		list["tmr"] = TransFloat(ca * Hrate)
 
- 		list["cyl"] = TransFloat(ca * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = p
 
- 		list["index"] = "磷(g)"
 
- 		list["tmr"] = TransFloat(p * Hrate)
 
- 		list["cyl"] = TransFloat(p * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = nmd
 
- 		list["index"] = "产奶净能(Mcal/DM)"
 
- 		list["tmr"] = TransFloat(nmd * Hrate)
 
- 		list["cyl"] = TransFloat(nmd * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = fat
 
- 		list["index"] = "脂肪"
 
- 		list["tmr"] = TransFloat(fat * Hrate)
 
- 		list["cyl"] = TransFloat(fat * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = starch
 
- 		list["index"] = "淀粉"
 
- 		list["tmr"] = TransFloat(starch * Hrate)
 
- 		list["cyl"] = TransFloat(starch * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = ndf
 
- 		list["index"] = "NDF(%DM)"
 
- 		list["tmr"] = TransFloat(ndf * Hrate)
 
- 		list["cyl"] = TransFloat(ndf * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = cndf
 
- 		list["index"] = "粗料中的NDF(%DM)"
 
- 		list["tmr"] = TransFloat(cndf * Hrate)
 
- 		list["cyl"] = TransFloat(cndf * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = adf
 
- 		list["index"] = " ADF(%DM)"
 
- 		list["tmr"] = TransFloat(adf * Hrate)
 
- 		list["cyl"] = TransFloat(adf * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = cad
 
- 		list["index"] = "钙(%DM)"
 
- 		list["tmr"] = TransFloat(cad * Hrate)
 
- 		list["cyl"] = TransFloat(cad * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = pd
 
- 		list["index"] = " 磷(%DM)"
 
- 		list["tmr"] = TransFloat(pd * Hrate)
 
- 		list["cyl"] = TransFloat(pd * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = trans35f
 
- 		list["index"] = "(3.5)FCR(kg/DM)"
 
- 		list["tmr"] = TransFloat(trans35f * Hrate)
 
- 		list["cyl"] = TransFloat(trans35f * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["ft"] = trans4f
 
- 		list["index"] = "(4.0)FCR(kg/DM)"
 
- 		list["tmr"] = TransFloat(trans4f * Hrate)
 
- 		list["cyl"] = TransFloat(trans4f * Srate)
 
- 		data = append(data, list)
 
- 	}
 
- 	chartData["data"] = data
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func TransFloat(flo float64) float64 {
 
- 	hf, _ := strconv.ParseFloat(fmt.Sprintf("%.3f", float64(flo)), 64)
 
- 	return hf
 
- }
 
- func getAccuracyV7(queryList []map[string]interface{}) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	//list := make(map[string]interface{})
 
- 	data := []interface{}{}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		dry, _ := strconv.ParseFloat(queryList[i]["dry"].(string), 64)
 
- 		Hrate, _ := strconv.ParseFloat(queryList[i]["Hrate"].(string), 64)
 
- 		Srate, _ := strconv.ParseFloat(queryList[i]["Srate"].(string), 64)
 
- 		trans35f, _ := strconv.ParseFloat(queryList[i]["trans35f"].(string), 64)
 
- 		jcrate, _ := strconv.ParseFloat(queryList[i]["jcrate"].(string), 64)
 
- 		uprice, _ := strconv.ParseFloat(queryList[i]["uprice"].(string), 64)
 
- 		kprice, _ := strconv.ParseFloat(queryList[i]["dry"].(string), 64)
 
- 		list := make(map[string]interface{})
 
- 		list["tname"] = queryList[i]["tname"]
 
- 		list["ftid"] = queryList[i]["ftid"]
 
- 		list["ft"] = dry
 
- 		list["index"] = "干物质(kg)"
 
- 		list["tmr"] = TransFloat(dry * Hrate)
 
- 		list["cyl"] = TransFloat(dry * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["tname"] = queryList[i]["tname"]
 
- 		list["ftid"] = queryList[i]["ftid"]
 
- 		list["ft"] = trans35f
 
- 		list["index"] = "(3.5)FCR(kg/DM)"
 
- 		list["tmr"] = TransFloat(trans35f * Hrate)
 
- 		list["cyl"] = TransFloat(trans35f * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["tname"] = queryList[i]["tname"]
 
- 		list["ftid"] = queryList[i]["ftid"]
 
- 		list["ft"] = jcrate
 
- 		list["index"] = "粗精比(%)"
 
- 		list["tmr"] = TransFloat(jcrate * Hrate)
 
- 		list["cyl"] = TransFloat(jcrate * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["tname"] = queryList[i]["tname"]
 
- 		list["ftid"] = queryList[i]["ftid"]
 
- 		list["ft"] = uprice
 
- 		list["index"] = "日粮成本(元)"
 
- 		list["tmr"] = TransFloat(uprice * Hrate)
 
- 		list["cyl"] = TransFloat(uprice * Srate)
 
- 		data = append(data, list)
 
- 		list = make(map[string]interface{})
 
- 		list["tname"] = queryList[i]["tname"]
 
- 		list["ftid"] = queryList[i]["ftid"]
 
- 		list["ft"] = kprice
 
- 		list["index"] = "公斤奶成本"
 
- 		list["tmr"] = TransFloat(kprice * Hrate)
 
- 		list["cyl"] = TransFloat(kprice * Srate)
 
- 		data = append(data, list)
 
- 	}
 
- 	chartData["data"] = data
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV6(queryList []map[string]interface{}) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	data := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	data2 := []interface{}{}
 
- 	data3 := []interface{}{}
 
- 	data4 := []interface{}{}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		data = append(data, queryList[i]["牧场"])
 
- 		data1 = append(data1, queryList[i]["field1"])
 
- 		data2 = append(data2, queryList[i]["field2"])
 
- 		data3 = append(data3, queryList[i]["field3"])
 
- 		data4 = append(data4, queryList[i]["field4"])
 
- 	}
 
- 	chartData["data1"] = data
 
- 	chartData["data2"] = data1
 
- 	chartData["data3"] = data2
 
- 	chartData["data4"] = data3
 
- 	chartData["data5"] = data4
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV5(queryList []map[string]interface{}, typea int) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	datamap1 := make(map[string]interface{})
 
- 	datamap2 := make(map[string]interface{})
 
- 	temsmap := make(map[interface{}]interface{})
 
- 	mapc2 := make(map[interface{}]interface{})
 
- 	data3 := []interface{}{}
 
- 	datamap2child := make(map[string]interface{})
 
- 	data2 := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	var dtem interface{}
 
- 	var temstr interface{}
 
- 	var typestr interface{}
 
- 	count2 := 0
 
- 	a := 0
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		if i == 0 {
 
- 			temstr = queryList[i]["fname"]
 
- 			typestr = queryList[i]["typestr"]
 
- 		}
 
- 		if temstr == queryList[i]["fname"] {
 
- 			temsmap[queryList[i]["feedname"]] = 1
 
- 		}
 
- 		if _, ok := mapc2[queryList[i]["feedname"]]; !ok {
 
- 			mapc2[queryList[i]["feedname"]] = count2
 
- 			mapc2[count2] = queryList[i]["feedname"]
 
- 			count2++
 
- 		}
 
- 	}
 
- 	//for i := 0; i<count2 ; i++ {
 
- 	//	reslist := make([]map[string]interface{},1)
 
- 	//	res := make(map[string]interface{})
 
- 	//	res["fname"] = "分界线"
 
- 	//	res["feedname"] = mapc2[i]
 
- 	//	res["饲料名称"] = mapc2[i]
 
- 	//	reslist[0] = res
 
- 	//	queryList = append(reslist,queryList...)
 
- 	//}
 
- 	for i := 0; i < count2; i++ { // 将所有饲料种类新增为第一行 测试
 
- 		if _, ok := temsmap[mapc2[i]]; !ok {
 
- 			reslist := make([]map[string]interface{}, 1)
 
- 			res := make(map[string]interface{})
 
- 			res["fname"] = temstr
 
- 			res["feedname"] = mapc2[i]
 
- 			res["饲料名称"] = mapc2[i]
 
- 			res["typestr"] = typestr
 
- 			reslist[0] = res
 
- 			queryList = append(reslist, queryList...)
 
- 		}
 
- 	}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		a = mapc2[queryList[i]["feedname"]].(int) * 4
 
- 		if i == 0 {
 
- 			datamap2["label"] = "饲料名称"
 
- 			switch queryList[i]["typestr"].(type) {
 
- 			case string:
 
- 				datamap2child["label"] = queryList[i]["typestr"].(string) + "/饲料参数"
 
- 			default:
 
- 				datamap2child["label"] = "/饲料参数"
 
- 			}
 
- 			datamap2child["prop"] = "A"
 
- 			data3 = append(data3, datamap2child)
 
- 			datamap2["children"] = data3
 
- 			data2 = append(data2, datamap2)
 
- 			data3 = []interface{}{}
 
- 			datamap2child = make(map[string]interface{})
 
- 			datamap2 = make(map[string]interface{})
 
- 			dtem = queryList[i]["fname"]
 
- 		}
 
- 		if dtem != queryList[i]["fname"] && i != 0 {
 
- 			data1 = append(data1, datamap1)
 
- 			dtem = queryList[i]["fname"]
 
- 			datamap1 = make(map[string]interface{})
 
- 		}
 
- 		if queryList[i]["fname"] == temstr {
 
- 			datamap2["label"] = queryList[i]["feedname"]
 
- 			if typea == 0 || typea == 1 {
 
- 				datamap2child["label"] = "理论"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			if typea == 0 || typea == 2 {
 
- 				datamap2child["label"] = "实际"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+1)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			if typea == 0 || typea == 3 {
 
- 				datamap2child["label"] = "理论重量"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+2)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			if typea == 0 || typea == 4 {
 
- 				datamap2child["label"] = "实际重量"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+3)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			// datamap2child["label"] = "理论"
 
- 			// datamap2child["prop"] = "a" + strconv.Itoa(a)
 
- 			// data3 = append(data3, datamap2child)
 
- 			// datamap2child = make(map[string]interface{})
 
- 			// datamap2child["label"] = "实际"
 
- 			// datamap2child["prop"] = "a" + strconv.Itoa(a+1)
 
- 			// data3 = append(data3, datamap2child)
 
- 			// datamap2child = make(map[string]interface{})
 
- 			datamap2["children"] = data3
 
- 			data2 = append(data2, datamap2)
 
- 			data3 = []interface{}{}
 
- 			datamap2 = make(map[string]interface{})
 
- 			datamap2child = make(map[string]interface{})
 
- 		}
 
- 		datamap1["A"] = queryList[i]["fname"]
 
- 		datamap1["a"+strconv.Itoa(a)] = queryList[i]["lweight"]
 
- 		datamap1["a"+strconv.Itoa(a+1)] = queryList[i]["actualweightminus"]
 
- 		datamap1["a"+strconv.Itoa(a+2)] = queryList[i]["lweight1"]
 
- 		datamap1["a"+strconv.Itoa(a+3)] = queryList[i]["actualweightminus1"]
 
- 		datamap2["label"] = queryList[i]["饲料名称"]
 
- 		a = a + 4
 
- 	}
 
- 	data1 = append(data1, datamap1)
 
- 	chartData["data1"] = data1
 
- 	chartData["data2"] = data2
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV4(queryList []map[string]interface{}, queryListSum []map[string]interface{}, checked string, feednamesort3 []string, typea int) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	datamap1 := make(map[string]interface{})
 
- 	datamap2 := make(map[string]interface{})
 
- 	temsmap := make(map[interface{}]interface{})
 
- 	mapc2 := make(map[interface{}]interface{})
 
- 	mapc3 := make(map[interface{}]interface{})
 
- 	data3 := []interface{}{}
 
- 	datamap2child := make(map[string]interface{})
 
- 	data2 := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	a := 0
 
- 	//ss := 0
 
- 	var dtem interface{}
 
- 	count2 := 0
 
- 	var tem interface{}
 
- 	var temstr interface{}
 
- 	var typestr interface{}
 
- 	//var sort interface{}
 
- 	for i := 0; i < len(queryList); i++ { // 获取所有饲料种类
 
- 		if i == 0 {
 
- 			temstr = queryList[i]["fname"]
 
- 			typestr = queryList[i]["typestr"]
 
- 			//sort = queryList[i]["sort"]
 
- 		}
 
- 		if temstr == queryList[i]["fname"] {
 
- 			temsmap[queryList[i]["feedname"]] = 1
 
- 		}
 
- 		//if i == len(queryList)-1{
 
- 		//	temstr = "合计"
 
- 		//	typestr = queryList[i]["typestr"]
 
- 		//}
 
- 		if _, ok := mapc2[queryList[i]["feedname"]]; !ok {
 
- 			mapc2[queryList[i]["feedname"]] = count2 // 编号
 
- 			mapc2[count2] = queryList[i]["feedname"]
 
- 			count2++
 
- 		}
 
- 	}
 
- 	for i := 0; i < count2; i++ { // 将所有饲料种类新增为第一行 测试
 
- 		if _, ok := temsmap[mapc2[i]]; !ok {
 
- 			reslist := make([]map[string]interface{}, 1)
 
- 			res := make(map[string]interface{})
 
- 			res["fname"] = temstr
 
- 			res["feedname"] = mapc2[i]
 
- 			res["饲料名称"] = mapc2[i]
 
- 			res["typestr"] = typestr
 
- 			reslist[0] = res
 
- 			queryList = append(reslist, queryList...)
 
- 		}
 
- 	}
 
- 	//for i := 0; i<count2 ; i++ {
 
- 	//	reslist := make([]map[string]interface{},1)
 
- 	//	res := make(map[string]interface{})
 
- 	//	res["fname"] = "分界线"
 
- 	//	res["feedname"] = mapc2[i]
 
- 	//	res["饲料名称"] = mapc2[i]
 
- 	//	res["typestr"] =typestr
 
- 	//	reslist[0] = res
 
- 	//	queryList = append(reslist,queryList...)
 
- 	//}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		if i == 0 {
 
- 			tem = queryList[i]["fname"]
 
- 		}
 
- 		if queryList[i]["fname"] == tem {
 
- 			mapc3[queryList[i]["feedname"]] = i
 
- 		}
 
- 	}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		a = mapc2[queryList[i]["feedname"]].(int) * 4
 
- 		if i == 0 {
 
- 			datamap2["label"] = "饲料名称"
 
- 			switch queryList[i]["typestr"].(type) {
 
- 			case string:
 
- 				// datamap2child["label"] = queryList[i]["typestr"].(string) + "/饲料参数"
 
- 				datamap2child["label"] = queryList[i]["typestr"].(string)
 
- 			default:
 
- 				datamap2child["label"] = "/饲料参数"
 
- 			}
 
- 			datamap2child["prop"] = "A"
 
- 			data3 = append(data3, datamap2child)
 
- 			datamap2["children"] = data3
 
- 			data2 = append(data2, datamap2)
 
- 			data3 = []interface{}{}
 
- 			datamap2child = make(map[string]interface{})
 
- 			datamap2 = make(map[string]interface{})
 
- 			dtem = queryList[i]["fname"]
 
- 		}
 
- 		if dtem != queryList[i]["fname"] && i != 0 {
 
- 			data1 = append(data1, datamap1)
 
- 			dtem = queryList[i]["fname"]
 
- 			datamap1 = make(map[string]interface{})
 
- 		}
 
- 		if queryList[i]["fname"] == temstr {
 
- 			datamap2["label"] = queryList[i]["feedname"]
 
- 			if typea == 0 || typea == 1 {
 
- 				datamap2child["label"] = "理论"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			if typea == 0 || typea == 2 {
 
- 				datamap2child["label"] = "实际"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+1)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			if checked == "1" {
 
- 				datamap2child["label"] = "误差值"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+2)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 				datamap2child["label"] = "误差率"
 
- 				datamap2child["prop"] = "a" + strconv.Itoa(a+3)
 
- 				data3 = append(data3, datamap2child)
 
- 				datamap2child = make(map[string]interface{})
 
- 			}
 
- 			// datamap2 = make(map[string]interface{})
 
- 			if i != len(queryList)-1 {
 
- 				datamap2["children"] = data3
 
- 				data2 = append(data2, datamap2)
 
- 				datamap2 = make(map[string]interface{})
 
- 				data3 = []interface{}{}
 
- 			}
 
- 		}
 
- 		datamap1["A"] = queryList[i]["fname"]
 
- 		if queryList[i]["lweight"] != nil {
 
- 			var lweight float64
 
- 			lweight, _ = strconv.ParseFloat(queryList[i]["lweight"].(string), 64)
 
- 			datamap1["a"+strconv.Itoa(a)] = lweight
 
- 		} else {
 
- 			datamap1["a"+strconv.Itoa(a)] = queryList[i]["lweight"]
 
- 		}
 
- 		if queryList[i]["actualweightminus"] != nil {
 
- 			var actualweightminus float64
 
- 			actualweightminus, _ = strconv.ParseFloat(queryList[i]["actualweightminus"].(string), 64)
 
- 			datamap1["a"+strconv.Itoa(a+1)] = actualweightminus
 
- 		} else {
 
- 			datamap1["a"+strconv.Itoa(a+1)] = queryList[i]["actualweightminus"]
 
- 		}
 
- 		if checked == "1" {
 
- 			datamap1["a"+strconv.Itoa(a+2)] = queryList[i]["diff"]
 
- 			datamap1["a"+strconv.Itoa(a+3)] = queryList[i]["diffrate"]
 
- 		}
 
- 		datamap2["label"] = queryList[i]["饲料名称"]
 
- 		for z := 0; z < len(queryListSum); z++ {
 
- 			if queryListSum[z]["fname"] == queryList[i]["fname"] {
 
- 				if queryListSum[z]["lweight"] != nil {
 
- 					var lweight float64
 
- 					lweight, _ = strconv.ParseFloat(queryListSum[z]["lweight"].(string), 64)
 
- 					datamap1["B"] = lweight
 
- 				} else {
 
- 					datamap1["B"] = queryListSum[z]["lweight"]
 
- 				}
 
- 				if queryListSum[z]["actualweightminus"] != nil {
 
- 					var actualweightminus float64
 
- 					actualweightminus, _ = strconv.ParseFloat(queryListSum[z]["actualweightminus"].(string), 64)
 
- 					datamap1["C"] = actualweightminus
 
- 				} else {
 
- 					datamap1["B"] = queryListSum[z]["actualweightminus"]
 
- 				}
 
- 			}
 
- 		}
 
- 		if queryList[i]["fname"] == "合计" {
 
- 			var lweightSum, actualweightminusSum float64
 
- 			for z := 0; z < len(queryListSum); z++ {
 
- 				if queryListSum[z]["lweight"] != nil {
 
- 					var lweight float64
 
- 					lweight, _ = strconv.ParseFloat(queryListSum[z]["lweight"].(string), 64)
 
- 					lweightSum += lweight
 
- 				}
 
- 				if queryListSum[z]["actualweightminus"] != nil {
 
- 					var actualweightminus float64
 
- 					actualweightminus, _ = strconv.ParseFloat(queryListSum[z]["actualweightminus"].(string), 64)
 
- 					actualweightminusSum += actualweightminus
 
- 				}
 
- 				datamap1["B"] = lweightSum
 
- 				datamap1["C"] = actualweightminusSum
 
- 			}
 
- 		}
 
- 		if i == len(queryList)-1 {
 
- 			datamap2["label"] = "合计"
 
- 			if typea == 0 || typea == 1 {
 
- 				datamap2child = make(map[string]interface{})
 
- 				datamap2child["label"] = "理论"
 
- 				datamap2child["prop"] = "B"
 
- 				data3 = append(data3, datamap2child)
 
- 			}
 
- 			if typea == 0 || typea == 2 {
 
- 				datamap2child = make(map[string]interface{})
 
- 				datamap2child["label"] = "实际"
 
- 				datamap2child["prop"] = "C"
 
- 				data3 = append(data3, datamap2child)
 
- 			}
 
- 			//	###########################
 
- 			datamap2["children"] = data3
 
- 			data2 = append(data2, datamap2)
 
- 			datamap2 = make(map[string]interface{})
 
- 			data3 = []interface{}{}
 
- 		}
 
- 	}
 
- 	//var sortSum []string
 
- 	//for z := 0; z < len(data2); z++ {
 
- 	//	ss := data2[z].(map[string]interface{})
 
- 	//	bb := ss["label"].(string)
 
- 	//	if bb != "合计" {
 
- 	//		sortSum = append(sortSum, bb)
 
- 	//	}
 
- 	//}
 
- 	//sort.Strings(sortSum)
 
- 	//fmt.Println(sortSum)
 
- 	theEndSort := []interface{}{}
 
- 	for ii := 0; ii < len(data2); ii++ {
 
- 		ss := data2[ii].(map[string]interface{})
 
- 		bb := ss["label"].(string)
 
- 		if "饲料名称" == bb {
 
- 			theEndSort = append(theEndSort, data2[ii])
 
- 		}
 
- 	}
 
- 	for _, v := range feednamesort3 {
 
- 		for ii := 0; ii < len(data2); ii++ {
 
- 			ss := data2[ii].(map[string]interface{})
 
- 			bb := ss["label"].(string)
 
- 			// fmt.Println(bb)
 
- 			if v == bb && "饲料名称" != bb {
 
- 				theEndSort = append(theEndSort, data2[ii])
 
- 			}
 
- 		}
 
- 	}
 
- 	for ii := 0; ii < len(data2); ii++ {
 
- 		ss := data2[ii].(map[string]interface{})
 
- 		bb := ss["label"].(string)
 
- 		if "合计" == bb {
 
- 			theEndSort = append(theEndSort, data2[ii])
 
- 		}
 
- 	}
 
- 	data1 = append(data1, datamap1)
 
- 	chartData["data1"] = data1
 
- 	chartData["data2"] = theEndSort
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV3(queryList []map[string]interface{}) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	data := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	data2 := []interface{}{}
 
- 	data3 := []interface{}{}
 
- 	data4 := []interface{}{}
 
- 	//
 
- 	t1 := make(map[interface{}]string, 0)
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		data = append(data, queryList[i]["mtime"])
 
- 		data1 = append(data1, queryList[i]["lweight"])
 
- 		data2 = append(data2, queryList[i]["weight"])
 
- 		//data3 = append(data3, queryList[i]["field3"])
 
- 		//data4 = append(data4, queryList[i]["field4"])
 
- 		if _, ok := t1[queryList[i]["id"]]; !ok {
 
- 			datatem := []interface{}{}
 
- 			datatem = append(datatem, queryList[i]["startstime"], queryList[i]["lastactualweight"])
 
- 			data3 = append(data3, datatem)
 
- 			datatem2 := []interface{}{}
 
- 			datatem2 = append(datatem2, queryList[i]["intime"], queryList[i]["actualweight"])
 
- 			data4 = append(data4, datatem2)
 
- 			//datatem = []interface{}{}
 
- 		}
 
- 		t1[queryList[i]["id"]] = "1"
 
- 	}
 
- 	//
 
- 	chartData["data1"] = data
 
- 	chartData["data2"] = data1
 
- 	chartData["data3"] = data2
 
- 	chartData["data4"] = data3
 
- 	chartData["data5"] = data4
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracyV2(queryList []map[string]interface{}) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	data := []interface{}{}
 
- 	data1 := []interface{}{}
 
- 	data2 := []interface{}{}
 
- 	data3 := []interface{}{}
 
- 	data4 := []interface{}{}
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		data = append(data, queryList[i]["日期"])
 
- 		data1 = append(data1, queryList[i]["field1"])
 
- 		data2 = append(data2, queryList[i]["field2"])
 
- 		data3 = append(data3, queryList[i]["field3"])
 
- 		data4 = append(data4, queryList[i]["field4"])
 
- 	}
 
- 	chartData["data1"] = data
 
- 	chartData["data2"] = data1
 
- 	chartData["data3"] = data2
 
- 	chartData["data4"] = data3
 
- 	chartData["data5"] = data4
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- func getAccuracy(queryList []map[string]interface{}, layout string) (map[string]interface{}, error) {
 
- 	queryData := make(map[string]interface{})
 
- 	chartData := make(map[string]interface{})
 
- 	t1 := make(map[interface{}]interface{}, 0)
 
- 	t2 := make(map[interface{}]interface{}, 0)
 
- 	data := make(map[string][]interface{}, 0)
 
- 	t := make([]map[string][]interface{}, 0)
 
- 	e1 := []interface{}{}
 
- 	e2 := []string{}
 
- 	for _, value := range queryList {
 
- 		if _, ok := t1[value["名称"]]; !ok {
 
- 			e1 = append(e1, value["名称"])
 
- 		}
 
- 		if _, ok := t2[value["日期"]]; !ok {
 
- 			switch value["日期"].(type) {
 
- 			case string:
 
- 				e2 = append(e2, value["日期"].(string))
 
- 			}
 
- 		}
 
- 		t1[value["名称"]] = value["名称"]
 
- 		t2[value["日期"]] = value["日期"]
 
- 	}
 
- 	sort.Strings(e2)
 
- 	var b interface{}
 
- 	a := 0
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		if i == 0 {
 
- 			b = queryList[i]["名称"]
 
- 		}
 
- 		if b != queryList[i]["名称"] {
 
- 			if a < len(e2)-1 {
 
- 				eee := len(e2) - a
 
- 				fmt.Println(eee)
 
- 				for k := 0; k < len(e2)-a; k++ {
 
- 					data["data"] = append(data["data"], "")
 
- 				}
 
- 			}
 
- 			t = append(t, data)
 
- 			data = make(map[string][]interface{}, 0)
 
- 			b = queryList[i]["名称"]
 
- 			a = 0
 
- 		}
 
- 		switch queryList[i]["日期"].(type) {
 
- 		case string:
 
- 			dates, _ := time.Parse(layout, queryList[i]["日期"].(string))
 
- 			dates1 := ""
 
- 			if a < len(e2)-1 {
 
- 				dates1 = e2[a]
 
- 			} else {
 
- 				dates1 = e2[len(e2)-1]
 
- 			}
 
- 			if a < len(e2)-1 {
 
- 				if e2[a] != queryList[i]["日期"].(string) {
 
- 					if e2[a] < queryList[i]["日期"].(string) {
 
- 						dates1 = queryList[i]["日期"].(string)
 
- 						dates, _ = time.Parse(layout, e2[a])
 
- 						for ; a < len(e2)-1; a++ {
 
- 							if e2[a] >= queryList[i]["日期"].(string) {
 
- 								break
 
- 							}
 
- 						}
 
- 					}
 
- 					if layout == "2006-01-02" {
 
- 						for ; dates.Format(layout) < dates1; dates = dates.Add(24 * time.Hour) {
 
- 							data["data"] = append(data["data"], "")
 
- 						}
 
- 					} else if layout == "2006-01" {
 
- 						for ; dates.Format(layout) < dates1; dates = dates.AddDate(0, 1, 0) {
 
- 							data["data"] = append(data["data"], "")
 
- 						}
 
- 					}
 
- 				}
 
- 			}
 
- 		}
 
- 		data["data"] = append(data["data"], queryList[i]["准确率"])
 
- 		a++
 
- 	}
 
- 	if a < len(e2)-1 {
 
- 		for k := 0; k < len(e2)-a; k++ {
 
- 			data["data"] = append(data["data"], "")
 
- 		}
 
- 	}
 
- 	t = append(t, data)
 
- 	chartData["data1"] = e1
 
- 	chartData["data2"] = e2
 
- 	chartData["data3"] = t
 
- 	queryData["list"] = chartData
 
- 	queryData["code"] = 0
 
- 	queryData["message"] = "ok"
 
- 	queryData["data"] = queryList
 
- 	return queryData, nil
 
- }
 
- //统计分析过程分析data值拆分
 
- func GetprocessAnalysisTB(parammaps *gofasion.Fasion, tx *xorm.Session, quertDataList interface{}, queryList []map[string]interface{}) (query map[string]interface{}, err error) {
 
- 	sql1, p1 := restful.GetSqlByNameDBT("getweightjson", tx)
 
- 	query1 := make(map[string]interface{}, 0)
 
- 	s_params1 := make([]interface{}, 0)
 
- 	if sql1 != "" {
 
- 		paramslist := strings.Split(p1, ",")
 
- 		if len(paramslist) > 0 && p1 != "" {
 
- 			for _, value := range paramslist {
 
- 				s_params1 = append(s_params1, parammaps.Get(strings.Trim(value, " ")).ValueStr())
 
- 			}
 
- 		}
 
- 	}
 
- 	queryList2, err := tx.SQL(sql1, s_params1...).Query().List()
 
- 	if len(queryList2) == 0 {
 
- 		return query1, nil
 
- 	}
 
- 	if err != nil {
 
- 		fmt.Println("查询配料出错")
 
- 		return nil, err
 
- 	}
 
- 	//fmt.Printf("%T\n",queryList2[0]["weightjson"])
 
- 	b, _ := json.Marshal(&quertDataList)
 
- 	var m map[string]interface{}
 
- 	_ = json.Unmarshal(b, &m)
 
- 	msg := queryList2[0]["weightjson"].(string)
 
- 	weightjson := make([]map[string]string, 0)
 
- 	json.Unmarshal([]byte(msg), &weightjson)
 
- 	//fmt.Println(len(weightjson))
 
- 	realWandT := make([]interface{}, 0)
 
- 	for i := 0; i < len(weightjson); i++ {
 
- 		oneSlice := make([]interface{}, 0)
 
- 		oneSlice = append(oneSlice, weightjson[i]["mt"])
 
- 		oneSlice = append(oneSlice, weightjson[i]["w"])
 
- 		realWandT = append(realWandT, oneSlice)
 
- 	}
 
- 	WTime := make([]interface{}, 0)
 
- 	for z := 0; z < len(weightjson); z++ {
 
- 		WTime = append(WTime, weightjson[z]["mt"])
 
- 	}
 
- 	data2 := make([]interface{}, 0)
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		querySlice := make([]interface{}, 0)
 
- 		querySlice = append(querySlice, queryList[i]["timedate"], queryList[i]["lweight"])
 
- 		data2 = append(data2, querySlice)
 
- 	}
 
- 	data5 := make([]interface{}, 0)
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		querySlice := make([]interface{}, 0)
 
- 		querySlice = append(querySlice, queryList[i]["intime"], queryList[i]["actualweight"], queryList[i]["allname"], queryList[i]["fname"])
 
- 		data5 = append(data5, querySlice)
 
- 	}
 
- 	query1["WTime"] = WTime
 
- 	query1["data2"] = data2
 
- 	query1["data5"] = data5
 
- 	query1["realWandT"] = realWandT
 
- 	return query1, nil
 
- }
 
- type Columns struct {
 
- 	Prop  string `json:"prop"`
 
- 	Label string `json:"label"`
 
- }
 
- func getAccuracyV41(queryList []map[string]interface{}, queryListSum []map[string]interface{}, checked string, feednamesort3 []string, typea int, feednameCodes []map[string]interface{}) (map[string]interface{}, error) {
 
- 	columns := make([]*Columns, 0)
 
- 	columns = append(columns, &Columns{
 
- 		Prop:  "A",
 
- 		Label: "饲料编码",
 
- 	})
 
- 	columns = append(columns, &Columns{
 
- 		Prop:  "B",
 
- 		Label: "饲料名称",
 
- 	})
 
- 	label := "类别"
 
- 	// column1 := new(Columns)
 
- 	columns1 := make([]*Columns, 0)
 
- 	dataList := make([]map[string]interface{}, 0)
 
- 	for i := 0; i < len(queryList); i++ {
 
- 		label = queryList[i]["typestr"].(string)
 
- 		exist1 := false
 
- 		for _, data := range dataList {
 
- 			if data["B"].(string) == queryList[i]["feedname"].(string) {
 
- 				exist1 = true
 
- 			}
 
- 		}
 
- 		if !exist1 {
 
- 			data1 := make(map[string]interface{}, 0)
 
- 			data2 := make(map[string]interface{}, 0)
 
- 			for _, v := range feednameCodes {
 
- 				if v["feedname"].(string) == queryList[i]["feedname"].(string) {
 
- 					data1["A"] = v["feedcode"]
 
- 					data2["A"] = v["feedcode"]
 
- 					break
 
- 				}
 
- 			}
 
- 			data1["B"] = queryList[i]["feedname"]
 
- 			data1["C"] = "理论"
 
- 			// data1[queryList[i]["fname"].(string)] = 0
 
- 			dataList = append(dataList, data1)
 
- 			data2["B"] = queryList[i]["feedname"]
 
- 			data2["C"] = "实际"
 
- 			// data2[queryList[i]["fname"].(string)] = 0
 
- 			dataList = append(dataList, data2)
 
- 		}
 
- 		column := new(Columns)
 
- 		column.Prop = queryList[i]["fname"].(string)
 
- 		column.Label = queryList[i]["fname"].(string)
 
- 		exist := false
 
- 		for _, c := range columns1 {
 
- 			if c.Prop == queryList[i]["fname"].(string) {
 
- 				exist = true
 
- 			}
 
- 		}
 
- 		if exist {
 
- 			continue
 
- 		}
 
- 		columns1 = append(columns1, column)
 
- 	}
 
- 	for _, data := range dataList {
 
- 		for _, c := range columns1 {
 
- 			data[c.Prop] = 0
 
- 		}
 
- 	}
 
- 	data1 := make(map[string]interface{}, 0)
 
- 	data2 := make(map[string]interface{}, 0)
 
- 	data1["B"] = "合计"
 
- 	data1["C"] = "理论"
 
- 	data2["B"] = "合计"
 
- 	data2["C"] = "实际"
 
- 	for _, c := range columns1 {
 
- 		if c.Prop != "合计" {
 
- 			data1[c.Prop] = 0.0
 
- 			data2[c.Prop] = 0.0
 
- 		}
 
- 	}
 
- 	columns = append(columns, &Columns{
 
- 		Prop:  "C",
 
- 		Label: label,
 
- 	})
 
- 	columns = append(columns, columns1...)
 
- 	for _, data := range dataList {
 
- 		for i := 0; i < len(queryList); i++ {
 
- 			if queryList[i]["feedname"].(string) == data["B"] {
 
- 				if data["C"].(string) == "理论" {
 
- 					f1, _ := strconv.ParseFloat(fmt.Sprintf("%v", queryList[i]["lweight"]), 64)
 
- 					data[queryList[i]["fname"].(string)] = Round(f1, 2)
 
- 				} else {
 
- 					if queryList[i]["actualweightminus"] == nil {
 
- 						data[queryList[i]["fname"].(string)] = 0.0
 
- 					} else {
 
- 						f1, _ := strconv.ParseFloat(fmt.Sprintf("%v", queryList[i]["actualweightminus"]), 64)
 
- 						data[queryList[i]["fname"].(string)] = Round(f1, 2)
 
- 					}
 
- 				}
 
- 			}
 
- 		}
 
- 	}
 
- 	for _, data := range dataList {
 
- 		for _, c := range columns1 {
 
- 			if c.Prop != "合计" {
 
- 				if data["C"].(string) == "理论" {
 
- 					f1, _ := strconv.ParseFloat(fmt.Sprintf("%v", data1[c.Prop]), 64)
 
- 					f2, _ := strconv.ParseFloat(fmt.Sprintf("%v", data[c.Prop]), 64)
 
- 					data1[c.Prop] = Round(f1+f2, 2)
 
- 				} else {
 
- 					f1, _ := strconv.ParseFloat(fmt.Sprintf("%v", data2[c.Prop]), 64)
 
- 					f2, _ := strconv.ParseFloat(fmt.Sprintf("%v", data[c.Prop]), 64)
 
- 					data2[c.Prop] = Round(f1+f2, 2)
 
- 				}
 
- 			}
 
- 		}
 
- 	}
 
- 	dataList = append(dataList, data1)
 
- 	dataList = append(dataList, data2)
 
- 	respData := make(map[string]interface{})
 
- 	respData["data"] = dataList
 
- 	respData["columns"] = columns
 
- 	return respData, nil
 
- }
 
- func Round(number float64, size int) float64 {
 
- 	return math.Round(number*100) / 100
 
- }
 
 
  |