controller.go 9.5 KB

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