controller.go 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. package controller
  2. import (
  3. "bswas/excel"
  4. "bswas/orm"
  5. "bswas/utilities"
  6. "encoding/json"
  7. "fmt"
  8. "net/http"
  9. "strconv"
  10. "time"
  11. )
  12. func Export(w http.ResponseWriter,req *http.Request) {
  13. errorMsg := utilities.NewError()
  14. decoder := json.NewDecoder(req.Body)
  15. var params map[string]string
  16. // 解析参数 存入map
  17. e := decoder.Decode(&params)
  18. if e != nil{
  19. utilities.WriteLog("/api/controller/controller.go:18 参数解析失败!","ERROR")
  20. }
  21. file := excel.CreateFile(selectCreateFormat(params))
  22. if errorMsg.GetMsg() != "" {
  23. w.Header().Set("Msg",errorMsg.GetMsg())
  24. w.WriteHeader(500)
  25. return
  26. }
  27. if _, err := file.WriteTo(w); err != nil {
  28. utilities.WriteLog("/api/controller/controller.go:27 返回二进制流失败!","ERROR")
  29. return
  30. }
  31. }
  32. type base struct {
  33. ROW []interface{} `json:"row"`
  34. LIST [][]interface{} `json:"list"`
  35. MERGEROW map[string]string `json:"mergeRow"`
  36. MERGECOLUMN []string `json:"mergeColumn"`
  37. }
  38. func selectCreateFormat(params map[string]string) (row []interface{}, list [][]interface{}, mergeRow map[string]string, mergeColumn []string){
  39. switch params["createFormat"] {
  40. case "merge":
  41. row, list, mergeRow, mergeColumn = selectModule(params)
  42. case "warpText":
  43. row, list, _, mergeColumn = selectModule(params)
  44. default:
  45. row, list, _, _ = selectModule(params)
  46. }
  47. return
  48. }
  49. func selectModule(params map[string]string) (row []interface{}, list [][]interface{}, mergeRow map[string]string, mergeColumn []string) {
  50. var data []map[string]string
  51. switch params["type"] {
  52. case "base":
  53. var val base
  54. err := json.Unmarshal([]byte(params["data"]),&val)
  55. if err != nil {
  56. utilities.WriteLog("/api/controller/controller.go:56 JSON解析失败!","ERROR")
  57. }
  58. row = val.ROW
  59. list = val.LIST
  60. mergeRow = val.MERGEROW
  61. mergeColumn = val.MERGECOLUMN
  62. case "waybill":
  63. data = orm.GetMysqlData(params["sql"])
  64. row, list = WaybillFormat(data)
  65. case "waybillDelivering":
  66. data = orm.GetMysqlData(params["sql"])
  67. row, list = WaybillDeliveringFormat(data)
  68. case "waybillFinancial":
  69. data = orm.GetMysqlData(params["sql"])
  70. row, list = WaybillFinancialFormat(data)
  71. case "rejected":
  72. data = orm.GetMysqlData(params["sql"])
  73. row, list, mergeRow = RejectedFormat(data)
  74. mergeColumn = []string{
  75. "A","B","C","D","E","F","G","H","I","J","K","T","U",
  76. }
  77. case "rejectedStatistics":
  78. data = orm.GetMysqlData(params["sql"])
  79. row, list = RejectedStatisticsFormat(data)
  80. case "order":
  81. data = orm.GetOracleData(params["sql"])
  82. row, list, mergeRow = OrderFormat(data)
  83. mergeColumn = []string{
  84. "A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P",
  85. "Q","R","S","Z","AA","AB","AC","AD",
  86. }
  87. case "orderWave":
  88. data = orm.GetOracleData(params["sql"])
  89. row, list = OrderWaveFormat(data)
  90. case "packageIssuedException":
  91. data = orm.GetMysqlData(params["sql"])
  92. row, list = PackageIssuedExceptionFormat(data)
  93. case "packageCreateException":
  94. data = orm.GetMysqlData(params["sql"])
  95. row, list = PackageCreateExceptionFormat(data)
  96. case "inventory":
  97. if params["sql"] != "" {
  98. data = orm.GetOracleData(params["sql"])
  99. }else{
  100. err := json.Unmarshal([]byte(params["data"]), &data)
  101. if err != nil {
  102. utilities.WriteLog("/api/controller/controller.go:102 库存数据json解析失败!","ERROR")
  103. }
  104. }
  105. row, list = InventoryFormat(data, true)
  106. case "allInventory":
  107. if params["sql"] != "" {
  108. data = orm.GetOracleData(params["sql"])
  109. }else{
  110. err := json.Unmarshal([]byte(params["data"]), &data)
  111. if err != nil {
  112. utilities.WriteLog("/api/controller/controller.go:112 全部库存数据json解析失败!","ERROR")
  113. }
  114. }
  115. row, list = InventoryFormat(data, false)
  116. case "process":
  117. data = orm.GetMysqlData(params["sql"])
  118. row, list, mergeRow = ProcessFormat(data)
  119. mergeColumn = []string{
  120. "A","B","C","D","E","F","G","H","I",
  121. }
  122. case "laborReport":
  123. err := json.Unmarshal([]byte(params["data"]), &data)
  124. if err != nil {
  125. utilities.WriteLog("/api/controller/controller.go:125 临时工报表数据json解析失败!","ERROR")
  126. }
  127. row, list = LaborReportFormat(data)
  128. case "orderIssue":
  129. t := time.Now()
  130. fmt.Println(t.Format("2006-01-02 15:04:05"))
  131. sqlList := make(map[string]string)
  132. err := json.Unmarshal([]byte(params["sqlList"]), &sqlList)
  133. if err != nil {
  134. utilities.WriteLog("/api/controller/controller.go:132 订单问题件数据json解析失败!","ERROR")
  135. }
  136. if sqlList["orderPackageSql"] == "" || sqlList["secondOrderPackageSql"] == "" || sqlList["orderIssueSql"] == "" || sqlList["rejectedBillItemSql"] == "" || sqlList["logSql"] == ""{
  137. return
  138. }
  139. orderIssues := orm.GetMysqlData(sqlList["orderIssueSql"])
  140. if len(orderIssues) < 1 {
  141. break
  142. }
  143. modelData, orderPackageConditionValue, secondOrderPackageConditionValue, rejectedBillItemConditionValue, logConditionValue := GetOrderIssuesModel(orderIssues)
  144. orderPackages := make([]map[string]string,0)
  145. secondOrderPackages := make([]map[string]string,0)
  146. rejectedBillItems := make([]map[string]string,0)
  147. logs := make([]map[string]string,0)
  148. OP := len(orderPackageConditionValue)
  149. SOP := len(secondOrderPackageConditionValue)
  150. RB := len(rejectedBillItemConditionValue)
  151. L := len(logConditionValue)
  152. if orderPackageConditionValue[OP-2:] != "()"{
  153. if orderPackageConditionValue[OP-2:OP-1] == "," {
  154. orderPackageConditionValue = orderPackageConditionValue[0:OP-2] + orderPackageConditionValue[OP-1:]
  155. }
  156. orderPackages = orm.GetMysqlData(sqlList["orderPackageSql"]+orderPackageConditionValue)
  157. }
  158. if secondOrderPackageConditionValue[len(secondOrderPackageConditionValue)-2:] != "()"{
  159. if secondOrderPackageConditionValue[SOP-2:SOP-1] == "," {
  160. secondOrderPackageConditionValue = secondOrderPackageConditionValue[0:SOP-2] + secondOrderPackageConditionValue[SOP-1:]
  161. }
  162. secondOrderPackages = orm.GetMysqlData(sqlList["secondOrderPackageSql"]+secondOrderPackageConditionValue)
  163. }
  164. if rejectedBillItemConditionValue[len(rejectedBillItemConditionValue)-2:] != "()"{
  165. if rejectedBillItemConditionValue[RB-2:RB-1] == "," {
  166. rejectedBillItemConditionValue = rejectedBillItemConditionValue[0:RB-2] + rejectedBillItemConditionValue[RB-1:]
  167. }
  168. rejectedBillItems = orm.GetMysqlData(sqlList["rejectedBillItemSql"]+rejectedBillItemConditionValue)
  169. }
  170. if logConditionValue[len(logConditionValue)-2:] != "()"{
  171. if logConditionValue[L-2:L-1] == "," {
  172. logConditionValue = logConditionValue[0:L-2] + logConditionValue[L-1:]
  173. }
  174. logs = orm.GetMysqlData(sqlList["logSql"]+logConditionValue)
  175. }
  176. result := MergerOrderIssueData(modelData,orderPackages,secondOrderPackages,rejectedBillItems,logs)
  177. row, list, mergeRow = OrderIssueFormat(result)
  178. mergeColumn = []string{
  179. "A","B","C","D","E","F","G","H","I","J","K","L",
  180. "U","Y","Z","AA","AF","AG","AH","AI","AJ","AK",
  181. }
  182. t = time.Now()
  183. fmt.Println(t.Format("2006-01-02 15:04:05"))
  184. case "inventoryAccountMission":
  185. err := json.Unmarshal([]byte(params["data"]), &data)
  186. if err != nil {
  187. utilities.WriteLog("/api/controller/controller.go:183 库存盘点数据json解析失败!","ERROR")
  188. }
  189. row, list = InventoryAccountMissionFormat(data)
  190. case "inventoryCompare":
  191. data = orm.GetMysqlData(params["sql"])
  192. row, list = InventoryCompareFormat(data)
  193. case "unify":
  194. var column []string
  195. var rule map[string]string
  196. err := json.Unmarshal([]byte(params["row"]), &row)
  197. if err != nil {
  198. utilities.WriteLog("/api/controller/controller.go:194 参数传递错误!","ERROR")
  199. }
  200. err = json.Unmarshal([]byte(params["column"]), &column)
  201. if err != nil {
  202. utilities.WriteLog("/api/controller/controller.go:198 参数传递错误!","ERROR")
  203. }
  204. if params["mergeColumn"] != ""{
  205. err = json.Unmarshal([]byte(params["mergeColumn"]), &mergeColumn)
  206. if err != nil {
  207. utilities.WriteLog("/api/controller/controller.go:203 参数传递错误!","ERROR")
  208. }
  209. }
  210. err = json.Unmarshal([]byte(params["rule"]), &rule)
  211. if params["connection"] == "oracle" {
  212. data = orm.GetOracleData(params["sql"])
  213. }else{
  214. data = orm.GetMysqlData(params["sql"])
  215. }
  216. list, mergeRow = unifyFormat(data, column, rule, params["datum"])
  217. }
  218. return row,list,mergeRow,mergeColumn
  219. }
  220. func unifyFormat(data []map[string]string, row []string, rule map[string]string, datum string) ([][]interface{}, map[string]string){
  221. rowLen := len(row)
  222. column := make(map[string]int,rowLen)
  223. for i,c := range row {
  224. column[c] = i
  225. }
  226. list := make([][]interface{},len(data))
  227. mergeRow := make(map[string]string)
  228. var columnName string
  229. var startIndex int
  230. rowAmount := 0
  231. for k,v := range data{
  232. if datum != "" {
  233. if columnName == v[datum] {
  234. rowAmount++
  235. }else{
  236. if rowAmount != 0 {
  237. mergeRow[strconv.Itoa(startIndex+2)] = strconv.Itoa(startIndex+2+rowAmount)
  238. }
  239. columnName = v[datum]
  240. startIndex = k
  241. rowAmount = 0
  242. }
  243. if rowAmount != 0 {
  244. mergeRow[strconv.Itoa(startIndex+2)] = strconv.Itoa(startIndex+2+rowAmount)
  245. }
  246. }
  247. line := make([]interface{},rowLen)
  248. for key,value := range column {
  249. if rule[key] != ""{
  250. line[value] = dataFormat(rule[key], v[key])
  251. continue
  252. }
  253. line[value] = v[key]
  254. }
  255. list[k] = line
  256. }
  257. return list, mergeRow
  258. }
  259. func dataFormat(ruleType string,value string)string{
  260. switch ruleType {
  261. case "oracleDate":
  262. value = utilities.DateFormat(value, "2006-01-02T15:04:05+08:00")
  263. case "mysqlDate":
  264. value = utilities.DateFormat(value,"2006-01-02T15:04:05Z")
  265. case "percent":
  266. rate,_ := strconv.ParseFloat(value,64)
  267. if rate != 0 {
  268. value = strconv.FormatFloat(rate * 100, 'f', 2, 64)+"%"
  269. }
  270. }
  271. return value
  272. }