parsxlsx.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. package util
  2. import (
  3. "fmt"
  4. "log"
  5. "qfw/util"
  6. "strings"
  7. "time"
  8. "github.com/tealeg/xlsx"
  9. "gopkg.in/mgo.v2/bson"
  10. )
  11. const (
  12. Matchkey = "s_matchkey" //关键词
  13. Addkey = "s_addkey" //附加词
  14. Notkey = "s_notkey" //排除词
  15. Buyerclass = "s_buyerclass" //采购单位行业
  16. Topscopeclass = "s_topscopeclass" //行业-一级
  17. Subscopeclass = "s_subscopeclass" //行业-二级
  18. Globaladdkey = "s_globaladdkey" // 全局附加词
  19. Globalnotkey = "s_globalnotkey" //全局排除词
  20. Globalclearkey = "s_globalclearkey" //全局排除词
  21. Tagname = "s_name" //标签的关键词规则名称
  22. )
  23. var SES = util.SimpleEncrypt{Key: "topJYBX2019"}
  24. //通用标签相关字段
  25. var export_fields = []string{"s_userid", "s_name", "", "s_area", "s_city", "s_district", "s_toptype", "s_subtype", "i_starttime", "i_endtime", "s_budgetlimit", "s_bidamountlimit", "s_globaltopscopeclass", "s_globalsubscopeclass", "s_globalbuyerclass", "s_globaladdkey", "s_globaladdkeymatch", "s_globalnotkey", "s_globalnotkeymatch", "s_globalclearkey", "s_globalclearkeymatch", "s_existfields", "i_extfieldstype"}
  26. //关键词标签相关字段
  27. var export_o_rules = []string{"s_matchkey", "s_keymatch", "s_addkey", "s_addkeymatch", "s_notkey", "s_notkeymatch", "s_buyerclass"}
  28. //定义值为数字的多个匹配方式map
  29. var export_numfield = map[string]bool{
  30. "s_globaladdkeymatch": true,
  31. "s_globalnotkeymatch": true,
  32. "s_globalclearkeymatch": true,
  33. "s_keymatch": true,
  34. "s_addkeymatch": true,
  35. "s_notkeymatch": true,
  36. }
  37. //匹配方式map
  38. var export_matchtype = map[string]interface{}{
  39. "1": "标题匹配",
  40. "2": "全文匹配",
  41. "3": "标的物匹配",
  42. "4": "附件匹配",
  43. "5": "项目名称匹配",
  44. "6": "采购单位匹配",
  45. "7": "中标单位匹配",
  46. "8": "采购单位匹配(正则)",
  47. "9": "中标单位匹配(正则)",
  48. }
  49. //字段包类型
  50. var export_extfieldstype = map[string]interface{}{
  51. "1": "标准字段包",
  52. "2": "高级字段包",
  53. }
  54. /**
  55. * 导入关键词表格
  56. */
  57. func Parsxlsx(filebyte []byte) (map[string]interface{}, error) {
  58. rdata := make(map[string]interface{})
  59. tmps := make([]map[string]string, 0)
  60. file, err := xlsx.OpenBinary(filebyte)
  61. if err != nil {
  62. return rdata, err
  63. }
  64. gaddkeyArr := []string{}
  65. gnotkeyArr := []string{}
  66. clearkeyArr := []string{}
  67. for _, v := range file.Sheets {
  68. for ii, vv := range v.Rows {
  69. rule := make(map[string]string)
  70. if ii == 0 {
  71. //第一行跳过
  72. continue
  73. }
  74. for iii, vvv := range vv.Cells {
  75. gaddkeyArr, gnotkeyArr, clearkeyArr = writeMap(rule, iii, vvv.Value, gaddkeyArr, gnotkeyArr, clearkeyArr)
  76. }
  77. tmps = append(tmps, rule)
  78. }
  79. }
  80. rdata["o_rules"] = tmps
  81. if len(gaddkeyArr) >= 1 {
  82. rdata[Globaladdkey] = strings.Join(gaddkeyArr, ",")
  83. }
  84. if len(gnotkeyArr) >= 1 {
  85. rdata[Globalnotkey] = strings.Join(gnotkeyArr, ",")
  86. }
  87. if len(clearkeyArr) >= 1 {
  88. rdata[Globalclearkey] = strings.Join(clearkeyArr, ",")
  89. }
  90. return rdata, nil
  91. }
  92. /**
  93. * 导入关键词表格
  94. */
  95. func Parsxlsx1(filebyte []byte) (map[string]interface{}, error) {
  96. rdata := make(map[string]interface{})
  97. tmps := make([]map[string]string, 0)
  98. file, err := xlsx.OpenBinary(filebyte)
  99. if err != nil {
  100. return rdata, err
  101. }
  102. for _, v := range file.Sheets {
  103. for ii, vv := range v.Rows {
  104. rule := make(map[string]string)
  105. if ii == 0 {
  106. //第一行跳过
  107. continue
  108. }
  109. for iii, vvv := range vv.Cells {
  110. writeMap1(rule, iii, vvv.Value)
  111. }
  112. tmps = append(tmps, rule)
  113. }
  114. }
  115. rdata["o_rules"] = tmps
  116. return rdata, nil
  117. }
  118. func writeMap(tmp map[string]string, i int, v string, addArr, notArr, clearkeyArr []string) ([]string, []string, []string) {
  119. switch i {
  120. case 0:
  121. if v != "" {
  122. //空格
  123. v = strings.TrimSpace(v)
  124. //中文逗号
  125. v = strings.ReplaceAll(v, ",", ",")
  126. tmp[Matchkey] = v
  127. }
  128. break
  129. case 1:
  130. if v != "" {
  131. v = strings.TrimSpace(v)
  132. v = strings.ReplaceAll(v, ",", ",")
  133. tmp[Addkey] = v
  134. }
  135. break
  136. case 2:
  137. if v != "" {
  138. v = strings.TrimSpace(v)
  139. v = strings.ReplaceAll(v, ",", ",")
  140. tmp[Notkey] = v
  141. }
  142. break
  143. case 3:
  144. if v != "" {
  145. v = strings.TrimSpace(v)
  146. v = strings.ReplaceAll(v, ",", ",")
  147. tmp[Buyerclass] = v
  148. }
  149. break
  150. case 4:
  151. if v != "" {
  152. v = strings.TrimSpace(v)
  153. v = strings.ReplaceAll(v, ",", ",")
  154. tmp[Topscopeclass] = v
  155. }
  156. break
  157. case 5:
  158. if v != "" {
  159. v = strings.TrimSpace(v)
  160. v = strings.ReplaceAll(v, ",", ",")
  161. tmp[Subscopeclass] = v
  162. }
  163. break
  164. case 6:
  165. if v != "" {
  166. v = strings.TrimSpace(v)
  167. v = strings.ReplaceAll(v, ",", ",")
  168. addArr = append(addArr, v)
  169. }
  170. break
  171. case 7:
  172. if v != "" {
  173. v = strings.TrimSpace(v)
  174. v = strings.ReplaceAll(v, ",", ",")
  175. notArr = append(notArr, v)
  176. }
  177. break
  178. case 8:
  179. if v != "" {
  180. v = strings.TrimSpace(v)
  181. v = strings.ReplaceAll(v, ",", ",")
  182. clearkeyArr = append(clearkeyArr, v)
  183. }
  184. break
  185. }
  186. return addArr, notArr, clearkeyArr
  187. }
  188. func writeMap1(tmp map[string]string, i int, v string) {
  189. switch i {
  190. case 0:
  191. if v != "" {
  192. //空格
  193. v = strings.TrimSpace(v)
  194. //中文逗号
  195. v = strings.ReplaceAll(v, ",", ",")
  196. tmp[Matchkey] = v
  197. }
  198. break
  199. case 1:
  200. if v != "" {
  201. v = strings.TrimSpace(v)
  202. v = strings.ReplaceAll(v, ",", ",")
  203. tmp[Addkey] = v
  204. }
  205. break
  206. case 2:
  207. if v != "" {
  208. v = strings.TrimSpace(v)
  209. v = strings.ReplaceAll(v, ",", ",")
  210. tmp[Notkey] = v
  211. }
  212. break
  213. case 3:
  214. if v != "" {
  215. v = strings.TrimSpace(v)
  216. v = strings.ReplaceAll(v, ",", ",")
  217. tmp[Tagname] = v
  218. }
  219. }
  220. }
  221. var bzpath, gjpath, rpath string = "web/res/标准字段包%d.xlsx", "web/res/高级字段包%d.xlsx", "web/res/%s_%d.xlsx"
  222. func ResponseXlsx_Data(id string) string {
  223. if id != "" {
  224. query := bson.M{
  225. "_id": bson.ObjectIdHex(id),
  226. }
  227. data, _ := Mgo.FindOne("cuserdepartrule", query)
  228. if (*data) != nil && len(*data) > 0 {
  229. isStandard := true
  230. if util.Int64All((*data)["i_extfieldstype"]) == Advanced {
  231. isStandard = false
  232. }
  233. data, _ := Mgo.Find("tagsdata", bson.M{"s_dataid": util.ObjToString((*data)["s_dataid"])}, nil, nil, false, -1, -1)
  234. if (*data) == nil || len(*data) == 0 {
  235. return ""
  236. }
  237. xf, err := xlsx.OpenFile("web/res/fields.xlsx")
  238. if err != nil {
  239. log.Println("fields file not foud", err.Error())
  240. return ""
  241. }
  242. if isStandard {
  243. sh := xf.Sheets[0]
  244. for i, v := range *data {
  245. row := sh.AddRow()
  246. row.AddCell().SetInt(i + 1)
  247. row.AddCell().SetValue(v["s_matchkey"])
  248. row.AddCell().SetValue(v["area"])
  249. row.AddCell().SetValue(v["city"])
  250. row.AddCell().SetValue(v["title"])
  251. row.AddCell().SetValue(v["subtype"])
  252. if v["publishtime"] != nil {
  253. row.AddCell().SetValue(time.Unix(util.Int64All(v["publishtime"]), 0).Format("2006-01-02"))
  254. } else {
  255. row.AddCell()
  256. }
  257. row.AddCell().SetValue(v["buyer"])
  258. row.AddCell().SetValue(v["winner"])
  259. if v["bidamount"] != nil {
  260. row.AddCell().SetFloat(util.Float64All(v["bidamount"]))
  261. } else {
  262. row.AddCell()
  263. }
  264. row.AddCell().SetValue(v["projectname"])
  265. row.AddCell().SetValue(v["detail"])
  266. row.AddCell().SetValue(v["s_jyhref"])
  267. }
  268. xf.Sheets = xf.Sheets[:1]
  269. xf.Sheets[0].Name = "详细数据"
  270. fname := fmt.Sprintf(bzpath, time.Now().Unix())
  271. err := xf.Save(fname)
  272. if err != nil {
  273. log.Println(err)
  274. return ""
  275. }
  276. return fname
  277. } else {
  278. sh := xf.Sheets[1]
  279. for _, v := range *data {
  280. row := sh.AddRow()
  281. // row.AddCell().SetInt(i + 1)
  282. row.AddCell().SetValue(v["s_matchkey"])
  283. row.AddCell().SetValue(v["area"])
  284. row.AddCell().SetValue(v["city"])
  285. row.AddCell().SetValue(v["title"])
  286. row.AddCell().SetValue(v["subtype"])
  287. row.AddCell().SetValue(v["detail"])
  288. if v["publishtime"] != nil {
  289. row.AddCell().SetValue(time.Unix(util.Int64All(v["publishtime"]), 0).Format("2006-01-02"))
  290. } else {
  291. row.AddCell()
  292. }
  293. row.AddCell().SetValue(v["href"])
  294. row.AddCell().SetValue(v["s_jyhref"])
  295. row.AddCell().SetValue(v["projectname"])
  296. row.AddCell().SetValue(v["projectcode"])
  297. row.AddCell().SetValue(v["projectscope"])
  298. if v["budget"] != nil {
  299. row.AddCell().SetFloat(util.Float64All(v["budget"]))
  300. } else {
  301. row.AddCell()
  302. }
  303. if v["bidamount"] != nil {
  304. row.AddCell().SetFloat(util.Float64All(v["bidamount"]))
  305. } else {
  306. row.AddCell()
  307. }
  308. if v["bidopentime"] != nil {
  309. row.AddCell().SetValue(time.Unix(util.Int64All(v["bidopentime"]), 0).Format("2006-01-02"))
  310. } else {
  311. row.AddCell()
  312. }
  313. row.AddCell().SetValue(v["buyer"])
  314. row.AddCell().SetValue(v["buyerperson"])
  315. row.AddCell().SetValue(v["buyertel"])
  316. row.AddCell().SetValue(v["agency"])
  317. row.AddCell().SetValue(v["s_winner"])
  318. row.AddCell().SetValue(v["winnerperson"])
  319. row.AddCell().SetValue(v["winnertel"])
  320. row.AddCell().SetValue(v["legal_person"])
  321. row.AddCell().SetValue(v["company_phone"])
  322. row.AddCell().SetValue(v["company_email"])
  323. ids := SES.EncodeString(util.ObjToString(v["info_id"]))
  324. row.AddCell().SetValue(ids)
  325. }
  326. xf.Sheets = xf.Sheets[1:2]
  327. xf.Sheets[0].Name = "详细数据"
  328. fname := fmt.Sprintf(gjpath, time.Now().Unix())
  329. err := xf.Save(fname)
  330. if err != nil {
  331. log.Println(err)
  332. return ""
  333. }
  334. return fname
  335. }
  336. }
  337. }
  338. return ""
  339. }
  340. func ResponseXlsx_Rule(id string) string {
  341. defer util.Catch()
  342. var data *map[string]interface{}
  343. data, _ = Mgo.FindById("cuserdepartrule", id, `{}`)
  344. if len(*data) == 0 {
  345. return ""
  346. }
  347. xf, err := xlsx.OpenFile("web/res/export_rule.xlsx") //读取导出标签模板表
  348. if err != nil {
  349. log.Println("export_rule file not foud", err.Error())
  350. return ""
  351. }
  352. sh := xf.Sheets[0]
  353. fields_len := len(export_fields)
  354. //
  355. for i, r := range sh.Rows {
  356. if i == fields_len {
  357. break
  358. }
  359. field := export_fields[i] //export_fields值的顺序与模板表一致
  360. if field == "i_extfieldstype" {
  361. r.AddCell().SetValue(export_extfieldstype[fmt.Sprint((*data)[field])])
  362. continue
  363. }
  364. if field == "s_userid" {
  365. userName, _ := Mgo.FindById("cuser", (*data)[field].(string), `{}`)
  366. r.AddCell().SetValue((*userName)["s_name"])
  367. continue
  368. }
  369. field_val := ""
  370. if strings.HasPrefix(field, "s_") {
  371. field_val = util.ObjToString((*data)[field])
  372. if export_numfield[field] { //找出值为数字的匹配方式,转换成中文
  373. field_val = numValToWord(field_val)
  374. }
  375. } else if strings.HasPrefix(field, "i_") { //i_startime i_endtime
  376. t := util.Int64All((*data)[field])
  377. if t > 0 {
  378. field_val = util.FormatDateByInt64(&t, util.Date_Full_Layout)
  379. }
  380. }
  381. r.AddCell().SetValue(field_val)
  382. }
  383. o_rules := (*data)["o_rules"].([]interface{})
  384. for _, o_rule := range o_rules {
  385. new_row := sh.AddRow()
  386. o_tmp := o_rule.(map[string]interface{})
  387. for _, match := range export_o_rules {
  388. cell_val := util.ObjToString(o_tmp[match])
  389. if export_numfield[match] { //找出值为数字的匹配方式,转换成中文
  390. cell_val = numValToWord(cell_val)
  391. }
  392. new_row.AddCell().SetValue(cell_val)
  393. }
  394. if s_topscopeclass := o_tmp["s_topscopeclass"]; s_topscopeclass != "" {
  395. new_row.AddCell().SetValue(s_topscopeclass)
  396. } else if s_subscopeclass := o_tmp["s_subscopeclass"]; s_subscopeclass != "" {
  397. new_row.AddCell().SetValue(s_subscopeclass)
  398. }
  399. }
  400. ruleName := (*data)["s_name"]
  401. fname := fmt.Sprintf(rpath, ruleName,time.Now().Unix())
  402. xf.Save(fname)
  403. return fname
  404. }
  405. //匹配方式的数字值,转为对应的汉字
  406. func numValToWord(numval string) (word string) {
  407. field_arr := strings.Split(numval, ",")
  408. for i, val := range field_arr {
  409. if i == 0 {
  410. word = util.ObjToString(export_matchtype[val])
  411. continue
  412. }
  413. word = word + "," + util.ObjToString(export_matchtype[val])
  414. }
  415. return
  416. }
  417. /**
  418. * 导入剑鱼批量修改数据
  419. */
  420. func ParsJyData(filebyte []byte) ([]map[string]interface{}, error) {
  421. var jyData []map[string]interface{}
  422. var keyName []string
  423. file, err := xlsx.OpenBinary(filebyte)
  424. if err != nil {
  425. return jyData, err
  426. }
  427. for i, v := range file.Sheets[0].Rows {
  428. data := make(map[string]interface{})
  429. for ii, vv := range v.Cells {
  430. if i == 0 {
  431. keyName = append(keyName, vv.Value)
  432. } else {
  433. if vv.Value != "" {
  434. data[keyName[ii]] = vv.Value
  435. }
  436. }
  437. }
  438. if len(data) > 0 {
  439. jyData = append(jyData, data)
  440. }
  441. }
  442. return jyData, nil
  443. }