parsxlsx.go 12 KB

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