wx_user.go 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758
  1. package services
  2. import (
  3. "context"
  4. "fmt"
  5. "hongze/hongze_cygx/models"
  6. "hongze/hongze_cygx/utils"
  7. "sort"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. func UpdateWxUserLabel(cont context.Context) (err error) {
  13. defer func() {
  14. if err != nil {
  15. go utils.SendAlarmMsg("更新用户标签失败;Err:"+err.Error(), 2)
  16. go utils.SendEmail("更新用户标签失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), ";Err:"+err.Error(), utils.EmailSendToUsers)
  17. utils.FileLog.Info("更新用户标签失败,Err:%s", err.Error())
  18. }
  19. }()
  20. //获取需要处理的权益客户
  21. listUser, err := models.GetUserRegisterList()
  22. if err != nil {
  23. fmt.Println("GetUserRegisterList Err", err)
  24. return err
  25. }
  26. mapChartCollect := make(map[string]int)
  27. //获取已经处理记录的用户并记录切片
  28. listChartCollectL, err := models.GetCygxChartCollectList()
  29. if err != nil && err.Error() != utils.ErrNoRow() {
  30. fmt.Println("GetCygxUserInteractionNumList Err", err)
  31. return err
  32. }
  33. for _, v := range listChartCollectL {
  34. mapChartCollect[fmt.Sprint("m:", v.Mobile, "u:", v.ChartId)] = v.UserId
  35. }
  36. var interactionNum int // 互动量
  37. mapComapnyInteractionNum := make(map[int]int)
  38. //拉取策略平台用户同步的图表信息
  39. {
  40. var chartMobile string
  41. var chartItems []*models.CygxChartCollect
  42. if utils.RunMode == "release" {
  43. for k, vUser := range listUser {
  44. if vUser.Mobile != "" {
  45. mobile := vUser.Mobile
  46. fmt.Println(vUser.Mobile, "_", k)
  47. chartMobile += mobile + ","
  48. listChart, _, _ := GetChartCollectionByApi(mobile, 9999, 0)
  49. if len(listChart) > 0 {
  50. for _, vChart := range listChart {
  51. if mapChartCollect[fmt.Sprint("m:", mobile, "u:", vChart.ChartId)] == 0 {
  52. item := new(models.CygxChartCollect)
  53. item.ChartId = vChart.ChartId
  54. t1, _ := time.Parse("2006-01-02T15:04:05Z", vChart.CreateDate)
  55. item.CreateTime = t1
  56. item.Mobile = mobile
  57. chartItems = append(chartItems, item)
  58. }
  59. }
  60. }
  61. }
  62. }
  63. }
  64. //如果有数据就添加
  65. if len(chartItems) > 0 {
  66. _, err = models.AddCygxChartCollectList(chartItems)
  67. if err != nil {
  68. fmt.Println(" RemoveChartCollectByMobile Err", err)
  69. }
  70. }
  71. //处理图表关注后的用户
  72. {
  73. listChartCollect, err := models.GetCygxChartCollectByMobileList()
  74. if err != nil {
  75. fmt.Println("GetCygxChartCollectByMobileList ,Err" + err.Error())
  76. }
  77. for k, v := range listChartCollect {
  78. if v.Mobile != "" {
  79. user, err := models.GetWxUserItemByMobile(v.Mobile)
  80. if err != nil && err.Error() != utils.ErrNoRow() {
  81. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  82. }
  83. if user != nil {
  84. fmt.Println(user.RealName, k)
  85. err = models.UpdateCygxChartCollect(user)
  86. if err != nil {
  87. fmt.Println("UpdateCygxChartCollect ,Err" + err.Error())
  88. }
  89. }
  90. }
  91. }
  92. }
  93. }
  94. //处理 前一天移动之后的用户的公司记录信息
  95. {
  96. startDate := time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
  97. endDate := time.Now().Format(utils.FormatDate)
  98. listUpdateUser, err := models.GetWxUserOpLogList(startDate, endDate)
  99. if err != nil && err.Error() != utils.ErrNoRow() {
  100. return err
  101. }
  102. var userIds string
  103. var mobiles string
  104. if len(listUpdateUser) > 0 {
  105. for _, v := range listUpdateUser {
  106. userIds += strconv.Itoa(v.UserId) + ","
  107. mobiles += "'" + v.Mobile + "',"
  108. }
  109. }
  110. userIds = strings.TrimRight(userIds, ",")
  111. mobiles = strings.TrimRight(mobiles, ",")
  112. //如果用户ID不为空那么就处理这些用户的记录信息
  113. if userIds != "" {
  114. var condition string
  115. //condition = ` AND user_id IN (` + userIds + `)`
  116. condition = ` AND mobile IN (` + mobiles + `)`
  117. //处理用户的文章收藏
  118. listCollect, err := models.GetCygxArticleCollectList(condition)
  119. if err != nil && err.Error() != utils.ErrNoRow() {
  120. fmt.Println("GetAddCygxArticleCollectList ,Err" + err.Error())
  121. }
  122. if len(listCollect) > 0 {
  123. for _, v := range listCollect {
  124. user, err := models.GetWxUserItemByUserId(v.UserId)
  125. if err != nil && err.Error() != utils.ErrNoRow() {
  126. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  127. }
  128. if user != nil {
  129. fmt.Println(user.RealName)
  130. err = models.UpdateCygxArticleCollect(user)
  131. if err != nil {
  132. fmt.Println("UpdateCygxArticleCollect ,Err" + err.Error())
  133. }
  134. }
  135. }
  136. }
  137. //处理用户的文章收藏 end
  138. //修改用户关注的产业
  139. listIndustryFllow, err := models.GetCygxIndustryFllowList(condition)
  140. if err != nil {
  141. fmt.Println("GetCygxIndustryFllowList ,Err" + err.Error())
  142. }
  143. for k, v := range listIndustryFllow {
  144. if v.Mobile != "" {
  145. user, err := models.GetWxUserItemByUserId(v.UserId)
  146. if err != nil && err.Error() != utils.ErrNoRow() {
  147. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  148. }
  149. if user != nil {
  150. fmt.Println(user.RealName, k)
  151. err = models.UpdateCygxIndustryFllow(user)
  152. if err != nil {
  153. fmt.Println("UpdateCygxIndustryFllow ,Err" + err.Error())
  154. }
  155. }
  156. }
  157. }
  158. //修改用户产业关注的产业end
  159. //修改用户的阅读记录
  160. listArticlePv, err := models.GetArticleHistoryRecordAllByMobileList(condition)
  161. if err != nil {
  162. fmt.Println("GetArticleHistoryRecordAllByMobileList ,Err" + err.Error())
  163. }
  164. for k, v := range listArticlePv {
  165. if v.Mobile != "" {
  166. user, err := models.GetWxUserItemByMobile(v.Mobile)
  167. if err != nil && err.Error() != utils.ErrNoRow() {
  168. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  169. }
  170. if user != nil {
  171. fmt.Println(user.RealName, k)
  172. err = models.UpdateCygxArticleHistoryRecordAll(user)
  173. if err != nil {
  174. fmt.Println("UpdateCygxArticleCollect ,Err" + err.Error())
  175. }
  176. }
  177. }
  178. }
  179. //修改用户的阅读记录end
  180. //处理用户的搜索记录
  181. listSearch, err := models.GetCygxSearchKeyWordList(condition)
  182. if err != nil {
  183. fmt.Println("GetArticleHistoryRecordAllByMobileList ,Err" + err.Error())
  184. }
  185. for k, v := range listSearch {
  186. if v.Mobile != "" {
  187. user, err := models.GetWxUserItemByUserId(v.UserId)
  188. if err != nil && err.Error() != utils.ErrNoRow() {
  189. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  190. }
  191. if user != nil {
  192. fmt.Println(user.RealName, k)
  193. err = models.UpdateCygxSearchKeyWord(user)
  194. if err != nil {
  195. fmt.Println("UpdateCygxSearchKeyWord ,Err" + err.Error())
  196. }
  197. }
  198. }
  199. }
  200. // 处理用户的作者关注
  201. lisDepartmentF, err := models.GetArticleDepartmentFollowByMobileList(condition)
  202. if err != nil {
  203. fmt.Println("GetArticleDepartmentFollowByMobileList ,Err" + err.Error())
  204. return err
  205. }
  206. for k, v := range lisDepartmentF {
  207. if v.Mobile != "" {
  208. user, err := models.GetWxUserItemByUserId(v.UserId)
  209. if err != nil && err.Error() != utils.ErrNoRow() {
  210. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  211. }
  212. if user != nil {
  213. fmt.Println(user.RealName, k)
  214. err = models.UpdateCygxArticleDepartmentFollow(user)
  215. if err != nil {
  216. fmt.Println("UpdateCygxArticleDepartmentFollow ,Err" + err.Error())
  217. }
  218. }
  219. }
  220. }
  221. // 处理用户的作者关注end
  222. // 处理用户的活动视频播放
  223. listActivityVideo, err := models.GetActivityVideoHistoryByMobileList(condition)
  224. if err != nil {
  225. fmt.Println("GetArticleDepartmentFollowByMobileList ,Err" + err.Error())
  226. return err
  227. }
  228. for k, v := range listActivityVideo {
  229. if v.Mobile != "" {
  230. user, err := models.GetWxUserItemByUserId(v.UserId)
  231. if err != nil && err.Error() != utils.ErrNoRow() {
  232. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  233. }
  234. if user != nil {
  235. fmt.Println(user.RealName, k)
  236. err = models.UpdateCygxActivityVideoHistory(user)
  237. if err != nil {
  238. fmt.Println("UpdateCygxActivityVideoHistory ,Err" + err.Error())
  239. }
  240. }
  241. }
  242. }
  243. // 处理用户的活动视频播放end
  244. // 处理用户的活动音频播放
  245. listActivityVoice, err := models.GetActivityVoiceHistoryByMobileList(condition)
  246. if err != nil {
  247. fmt.Println("GetActivityVoiceHistoryByMobileList ,Err" + err.Error())
  248. return err
  249. }
  250. for k, v := range listActivityVoice {
  251. if v.Mobile != "" {
  252. user, err := models.GetWxUserItemByUserId(v.UserId)
  253. if err != nil && err.Error() != utils.ErrNoRow() {
  254. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  255. }
  256. if user != nil {
  257. fmt.Println(user.RealName, k)
  258. err = models.UpdateCygxActivityVoiceHistory(user)
  259. if err != nil {
  260. fmt.Println("UpdateCygxActivityVoiceHistory ,Err" + err.Error())
  261. }
  262. }
  263. }
  264. }
  265. // 处理用户的活动音频播放end
  266. // 处理用户产业视频的播放记录
  267. listMicroRoadshow, err := models.GetMicroRoadshowVideoHistoryByMobileList(condition)
  268. if err != nil {
  269. fmt.Println("GetMicroRoadshowVideoHistoryByMobileList ,Err" + err.Error())
  270. return err
  271. }
  272. for k, v := range listMicroRoadshow {
  273. if v.Mobile != "" {
  274. user, err := models.GetWxUserItemByUserId(v.UserId)
  275. if err != nil && err.Error() != utils.ErrNoRow() {
  276. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  277. }
  278. if user != nil {
  279. fmt.Println(user.RealName, k)
  280. err = models.UpdateCygxMicroRoadshowVideoHistory(user)
  281. if err != nil {
  282. fmt.Println("UpdateCygxMicroRoadshowVideoHistory ,Err" + err.Error())
  283. }
  284. }
  285. }
  286. }
  287. // 处理用户产业视频的播放记录 end
  288. //如果手机号不为空,则更新用户的报名信息
  289. if mobiles != "" {
  290. condition = ` AND mobile IN (` + mobiles + `)`
  291. listSingUp, err := models.GetCygxActivitySignupByMobileList(condition)
  292. if err != nil {
  293. fmt.Println("GetCygxChartCollectByMobileList ,Err" + err.Error())
  294. }
  295. //fmt.Println("更新用户的报名信息长度", len(listSingUp))
  296. for _, v := range listSingUp {
  297. if v.Mobile != "" {
  298. user, err := models.GetWxUserItemByMobile(v.Mobile)
  299. if err != nil && err.Error() != utils.ErrNoRow() {
  300. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  301. }
  302. if user != nil {
  303. err = models.UpdateCygxActivitySignup(user)
  304. if err != nil {
  305. fmt.Println("UpdateCygxActivitySignup ,Err" + err.Error())
  306. //return err
  307. }
  308. }
  309. }
  310. }
  311. }
  312. }
  313. }
  314. //处理用户标签
  315. for _, vUser := range listUser {
  316. labels, err := models.GetCygxCompanyUserListSplit(strconv.Itoa(vUser.UserId))
  317. if err != nil {
  318. fmt.Println("GetCygxCompanyUserListSplit Err", err)
  319. return err
  320. }
  321. mapLabels := make(map[string]string)
  322. var labelsListStr []*models.UserLabel
  323. mapActivityLabels := make(map[string]string)
  324. labelsList := strings.Split(labels, ",")
  325. for _, vL := range labelsList {
  326. if mapLabels[vL] == "" && vL != "" {
  327. mapLabels[vL] = vL
  328. item := new(models.UserLabel)
  329. item.Label = vL
  330. labelsListStr = append(labelsListStr, item)
  331. }
  332. }
  333. dateTime := time.Now().AddDate(0, -3, 0).Format(utils.FormatDate)
  334. listArticlePv, err := models.GetArticlePvCount(vUser.Mobile, vUser.Email, dateTime)
  335. if err != nil && err.Error() != utils.ErrNoRow() {
  336. fmt.Println("GetArticlePvCount Err", err)
  337. return err
  338. }
  339. var articleIds string
  340. mapArticleIdLabelTotal := make(map[string]int)
  341. mapArticleIdPv := make(map[int]int)
  342. if len(listArticlePv) > 0 {
  343. for _, v := range listArticlePv {
  344. articleIds += strconv.Itoa(v.ArticleId) + ","
  345. mapArticleIdPv[v.ArticleId] = v.Pv
  346. }
  347. articleIds = strings.TrimRight(articleIds, ",")
  348. //产业、标的标签
  349. listLabelName, err := models.GetArticleGroupyIndustryName(articleIds)
  350. if err != nil && err.Error() != utils.ErrNoRow() {
  351. fmt.Println("GetArticleGroupyIndustryName Err", err)
  352. return err
  353. }
  354. if len(listLabelName) > 0 {
  355. for _, v := range listLabelName {
  356. labelsIndustryList := strings.Split(v.IndustryName, "/")
  357. labelsSubjectList := strings.Split(v.SubjectName, "/")
  358. //添加产业统计
  359. if len(labelsIndustryList) > 0 {
  360. for _, vIn := range labelsIndustryList {
  361. if mapActivityLabels[vIn] != "" {
  362. mapArticleIdLabelTotal[vIn] += mapArticleIdPv[v.ArticleId]
  363. } else {
  364. mapArticleIdLabelTotal[vIn] = mapArticleIdPv[v.ArticleId]
  365. mapActivityLabels[vIn] = vIn
  366. }
  367. }
  368. }
  369. if len(labelsSubjectList) > 0 {
  370. //添加标的统计
  371. for _, vIn := range labelsSubjectList {
  372. if mapActivityLabels[vIn] != "" {
  373. mapArticleIdLabelTotal[vIn] += mapArticleIdPv[v.ArticleId]
  374. } else {
  375. mapArticleIdLabelTotal[vIn] = mapArticleIdPv[v.ArticleId]
  376. mapActivityLabels[vIn] = vIn
  377. }
  378. }
  379. }
  380. }
  381. }
  382. }
  383. articleIds, err = models.GetCygxArticleCollectId(vUser.UserId, dateTime)
  384. if err != nil && err.Error() != utils.ErrNoRow() {
  385. fmt.Println("GetCygxArticleCollectId Err", err)
  386. return err
  387. }
  388. if articleIds != "" {
  389. //产业、标的标签
  390. listLabelName, err := models.GetArticleGroupyIndustryName(articleIds)
  391. if err != nil && err.Error() != utils.ErrNoRow() {
  392. fmt.Println("GetArticleGroupyIndustryName Err", err)
  393. return err
  394. }
  395. if len(listLabelName) > 0 {
  396. for _, v := range listLabelName {
  397. labelsIndustryList := strings.Split(v.IndustryName, "/")
  398. labelsSubjectList := strings.Split(v.SubjectName, "/")
  399. //添加产业统计
  400. if len(labelsIndustryList) > 0 {
  401. for _, vIn := range labelsIndustryList {
  402. if mapActivityLabels[vIn] != "" {
  403. mapArticleIdLabelTotal[vIn] += 1
  404. } else {
  405. mapArticleIdLabelTotal[vIn] = 1
  406. mapActivityLabels[vIn] = vIn
  407. }
  408. }
  409. }
  410. if len(labelsSubjectList) > 0 {
  411. //添加标的统计
  412. for _, vIn := range labelsSubjectList {
  413. if mapActivityLabels[vIn] != "" {
  414. mapArticleIdLabelTotal[vIn] += 1
  415. } else {
  416. mapArticleIdLabelTotal[vIn] = 1
  417. mapActivityLabels[vIn] = vIn
  418. }
  419. }
  420. }
  421. }
  422. }
  423. }
  424. //活动标签计算
  425. listActivityPv, err := models.GetActivitySignCount(vUser.Mobile, dateTime)
  426. if err != nil && err.Error() != utils.ErrNoRow() {
  427. fmt.Println("GetActivitySignCount Err", err)
  428. return err
  429. }
  430. if len(listActivityPv) > 0 {
  431. for _, v := range listActivityPv {
  432. labelsList := strings.Split(v.Label, "-")
  433. for _, v2 := range labelsList {
  434. labelsListSon := strings.Split(v2, "/")
  435. for _, v3 := range labelsListSon {
  436. if mapActivityLabels[v3] != "" {
  437. mapArticleIdLabelTotal[v3] += 1
  438. } else {
  439. mapArticleIdLabelTotal[v3] = 1
  440. mapActivityLabels[v3] = v3
  441. }
  442. }
  443. }
  444. }
  445. }
  446. //对标签数量进行排序
  447. type KvPair struct {
  448. Key string
  449. Val int
  450. }
  451. tmpList := make([]KvPair, 0)
  452. for k, v := range mapArticleIdLabelTotal {
  453. tmpList = append(tmpList, KvPair{Key: k, Val: v})
  454. }
  455. sort.Slice(tmpList, func(i, j int) bool {
  456. return tmpList[i].Val > tmpList[j].Val // 降序
  457. })
  458. for _, v := range tmpList {
  459. if v.Key != "" {
  460. mapLabels[v.Key] = v.Key
  461. item := new(models.UserLabel)
  462. item.Label = v.Key
  463. labelsListStr = append(labelsListStr, item)
  464. }
  465. }
  466. var labelNew string
  467. for _, v := range labelsListStr {
  468. labelNew += v.Label + ","
  469. }
  470. labelNew = strings.TrimRight(labelNew, ",")
  471. if labelNew != "" {
  472. err = models.UpdateUserLabel(labelNew, vUser.UserId)
  473. if err != nil {
  474. fmt.Println("UpdateUserLabel Err", err)
  475. return err
  476. }
  477. }
  478. }
  479. //处理用户、机构互动量数据
  480. {
  481. var userIds string
  482. var itemsInteraction []*models.CygxUserInteractionNum
  483. mapUserInteraction := make(map[int]int)
  484. mapCompanyInteraction := make(map[int]int)
  485. mapCompanyInteractionItem := make(map[int]*models.CygxCompanyInteractionNum)
  486. //获取已经处理记录的用户并记录切片
  487. listUserInteractionNum, err := models.GetCygxUserInteractionNumList()
  488. if err != nil && err.Error() != utils.ErrNoRow() {
  489. fmt.Println("GetCygxUserInteractionNumList Err", err)
  490. return err
  491. }
  492. for _, v := range listUserInteractionNum {
  493. mapUserInteraction[v.UserId] = v.UserId
  494. }
  495. listCompanyInteractionNum, err := models.GetCygxCompanyInteractionNumList()
  496. if err != nil && err.Error() != utils.ErrNoRow() {
  497. fmt.Println("GetCygxUserInteractionNumList Err", err)
  498. return err
  499. }
  500. for _, v := range listCompanyInteractionNum {
  501. mapCompanyInteraction[v.CompanyId] = v.CompanyId
  502. }
  503. //处理用户互动量数据
  504. for kUser, vUser := range listUser {
  505. userIds += strconv.Itoa(vUser.UserId) + ","
  506. //一次查询一百个避免用户过多
  507. if kUser%100 == 0 {
  508. userIds = strings.TrimRight(userIds, ",")
  509. userUserInteractionList, err := models.GetCygxCompanyUserUserInteraction(userIds)
  510. if err != nil {
  511. fmt.Println("GetCygxCompanyUserUserInteraction Err", err)
  512. return err
  513. }
  514. //处理用户的互动量
  515. if len(userUserInteractionList) > 0 {
  516. for _, vsplit := range userUserInteractionList {
  517. interactionNum = vsplit.HistoryNum + vsplit.CountNum + vsplit.IndustryFllowNum + vsplit.DepartmentFollowNum + vsplit.KeyWordNum + vsplit.OnLineNum + vsplit.OfficeNum + vsplit.ChartCountNum + vsplit.TripNum + vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  518. if interactionNum > 0 {
  519. //更改用户的互动量
  520. err = models.UpdateUserInteractionNum(interactionNum, int(vsplit.UserId))
  521. if err != nil {
  522. fmt.Println("UpdateUserInteractionNum Err", err)
  523. return err
  524. }
  525. mapComapnyInteractionNum[vsplit.CompanyId] += interactionNum
  526. itemInteraction := new(models.CygxUserInteractionNum)
  527. itemInteraction.UserId = int(vsplit.UserId)
  528. itemInteraction.ArticleHistoryNum = vsplit.HistoryNum
  529. itemInteraction.ArticleCountNum = vsplit.CountNum
  530. itemInteraction.ChartCountNum = vsplit.ChartCountNum
  531. itemInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  532. itemInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  533. itemInteraction.KeyWordNum = vsplit.KeyWordNum
  534. itemInteraction.ActivityOnLineNum = vsplit.OnLineNum
  535. itemInteraction.ActivityOfficeNum = vsplit.OfficeNum
  536. itemInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  537. itemInteraction.TripNum = vsplit.TripNum
  538. itemInteraction.RoadshowVideoNum = vsplit.RoadshowVideoNum
  539. itemInteraction.ActivityVideoNum = vsplit.ActivityVideoNum
  540. itemInteraction.ActivityVoiceNum = vsplit.ActivityVoiceNum
  541. itemInteraction.RoadshowNum = vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  542. itemInteraction.CreateTime = time.Now()
  543. itemInteraction.ModifyTime = time.Now()
  544. //如果这个切片下的结构体没有值就给他初始值,如果有就跟后面的相加
  545. if mapCompanyInteractionItem[vsplit.CompanyId] == nil {
  546. itemCompanyInteraction := new(models.CygxCompanyInteractionNum)
  547. itemCompanyInteraction.CompanyId = vsplit.CompanyId
  548. itemCompanyInteraction.ArticleHistoryNum = vsplit.HistoryNum
  549. itemCompanyInteraction.ArticleCountNum = vsplit.CountNum
  550. itemCompanyInteraction.ChartCountNum = vsplit.ChartCountNum
  551. itemCompanyInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  552. itemCompanyInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  553. itemCompanyInteraction.KeyWordNum = vsplit.KeyWordNum
  554. itemCompanyInteraction.ActivityOnLineNum = vsplit.OnLineNum
  555. itemCompanyInteraction.ActivityOfficeNum = vsplit.OfficeNum
  556. itemCompanyInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  557. itemCompanyInteraction.TripNum = vsplit.TripNum
  558. itemCompanyInteraction.RoadshowVideoNum = vsplit.RoadshowVideoNum
  559. itemCompanyInteraction.ActivityVideoNum = vsplit.ActivityVideoNum
  560. itemCompanyInteraction.ActivityVoiceNum = vsplit.ActivityVoiceNum
  561. itemCompanyInteraction.RoadshowNum = vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  562. mapCompanyInteractionItem[vsplit.CompanyId] = itemCompanyInteraction
  563. mapCompanyInteractionItem[vsplit.CompanyId].CreateTime = time.Now()
  564. mapCompanyInteractionItem[vsplit.CompanyId].ModifyTime = time.Now()
  565. } else {
  566. fmt.Println("公司ID", vsplit.CompanyId)
  567. mapCompanyInteractionItem[vsplit.CompanyId].CompanyId = vsplit.CompanyId
  568. mapCompanyInteractionItem[vsplit.CompanyId].ArticleHistoryNum += vsplit.HistoryNum
  569. mapCompanyInteractionItem[vsplit.CompanyId].ArticleCountNum += vsplit.CountNum
  570. mapCompanyInteractionItem[vsplit.CompanyId].ChartCountNum += vsplit.ChartCountNum
  571. mapCompanyInteractionItem[vsplit.CompanyId].IndustryFllowNum += vsplit.IndustryFllowNum
  572. mapCompanyInteractionItem[vsplit.CompanyId].DepartmentFollowNum += vsplit.DepartmentFollowNum
  573. mapCompanyInteractionItem[vsplit.CompanyId].KeyWordNum += vsplit.KeyWordNum
  574. mapCompanyInteractionItem[vsplit.CompanyId].ActivityOnLineNum += vsplit.OnLineNum
  575. mapCompanyInteractionItem[vsplit.CompanyId].ActivityOfficeNum += vsplit.OfficeNum
  576. mapCompanyInteractionItem[vsplit.CompanyId].ActivityNum += vsplit.OnLineNum + vsplit.OfficeNum
  577. mapCompanyInteractionItem[vsplit.CompanyId].TripNum += vsplit.TripNum
  578. mapCompanyInteractionItem[vsplit.CompanyId].RoadshowVideoNum += vsplit.RoadshowVideoNum
  579. mapCompanyInteractionItem[vsplit.CompanyId].ActivityVideoNum += vsplit.ActivityVideoNum
  580. mapCompanyInteractionItem[vsplit.CompanyId].ActivityVoiceNum += vsplit.ActivityVoiceNum
  581. mapCompanyInteractionItem[vsplit.CompanyId].RoadshowNum += vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  582. }
  583. //如果存在就修改不存在就新增
  584. if mapUserInteraction[int(vsplit.UserId)] == 0 {
  585. itemsInteraction = append(itemsInteraction, itemInteraction)
  586. } else {
  587. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  588. if err != nil {
  589. fmt.Println("UpdateCygxUserInteractionNum Err", err)
  590. return err
  591. }
  592. fmt.Println(itemInteraction.UserId)
  593. }
  594. }
  595. }
  596. }
  597. userIds = ""
  598. }
  599. }
  600. userIds = strings.TrimRight(userIds, ",")
  601. if userIds != "" {
  602. userUserInteractionList, err := models.GetCygxCompanyUserUserInteraction(userIds)
  603. if err != nil {
  604. fmt.Println("GetCygxCompanyUserUserInteraction Err", err)
  605. return err
  606. }
  607. //fmt.Println("处理用户剩余的")
  608. //处理用户的互动量
  609. if len(userUserInteractionList) > 0 {
  610. for _, vsplit := range userUserInteractionList {
  611. interactionNum = vsplit.HistoryNum + vsplit.CountNum + vsplit.IndustryFllowNum + vsplit.DepartmentFollowNum + vsplit.KeyWordNum + vsplit.OnLineNum + vsplit.OfficeNum + vsplit.ChartCountNum + vsplit.TripNum + vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  612. if interactionNum > 0 {
  613. err = models.UpdateUserInteractionNum(interactionNum, int(vsplit.UserId))
  614. if err != nil {
  615. fmt.Println("UpdateUserInteractionNum Err", err)
  616. return err
  617. }
  618. mapComapnyInteractionNum[vsplit.CompanyId] += interactionNum
  619. itemInteraction := new(models.CygxUserInteractionNum)
  620. itemInteraction.UserId = int(vsplit.UserId)
  621. itemInteraction.ArticleHistoryNum = vsplit.HistoryNum
  622. itemInteraction.ArticleCountNum = vsplit.CountNum
  623. itemInteraction.ChartCountNum = vsplit.ChartCountNum
  624. itemInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  625. itemInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  626. itemInteraction.KeyWordNum = vsplit.KeyWordNum
  627. itemInteraction.ActivityOnLineNum = vsplit.OnLineNum
  628. itemInteraction.ActivityOfficeNum = vsplit.OfficeNum
  629. itemInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  630. itemInteraction.TripNum = vsplit.TripNum
  631. itemInteraction.RoadshowVideoNum = vsplit.RoadshowVideoNum
  632. itemInteraction.ActivityVideoNum = vsplit.ActivityVideoNum
  633. itemInteraction.ActivityVoiceNum = vsplit.ActivityVoiceNum
  634. itemInteraction.RoadshowNum = vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  635. //如果这个切片下的结构体没有值就给他初始值,如果有就跟后面的相加
  636. if mapCompanyInteractionItem[vsplit.CompanyId] == nil {
  637. itemCompanyInteraction := new(models.CygxCompanyInteractionNum)
  638. itemCompanyInteraction.CompanyId = vsplit.CompanyId
  639. itemCompanyInteraction.ArticleHistoryNum = vsplit.HistoryNum
  640. itemCompanyInteraction.ArticleCountNum = vsplit.CountNum
  641. itemCompanyInteraction.ChartCountNum = vsplit.ChartCountNum
  642. itemCompanyInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  643. itemCompanyInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  644. itemCompanyInteraction.KeyWordNum = vsplit.KeyWordNum
  645. itemCompanyInteraction.ActivityOnLineNum = vsplit.OnLineNum
  646. itemCompanyInteraction.ActivityOfficeNum = vsplit.OfficeNum
  647. itemCompanyInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  648. itemCompanyInteraction.TripNum = vsplit.TripNum
  649. itemCompanyInteraction.RoadshowVideoNum = vsplit.RoadshowVideoNum
  650. itemCompanyInteraction.ActivityVideoNum = vsplit.ActivityVideoNum
  651. itemCompanyInteraction.ActivityVoiceNum = vsplit.ActivityVoiceNum
  652. itemCompanyInteraction.RoadshowNum = vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  653. mapCompanyInteractionItem[vsplit.CompanyId] = itemCompanyInteraction
  654. mapCompanyInteractionItem[vsplit.CompanyId].CreateTime = time.Now()
  655. mapCompanyInteractionItem[vsplit.CompanyId].ModifyTime = time.Now()
  656. } else {
  657. mapCompanyInteractionItem[vsplit.CompanyId].CompanyId = vsplit.CompanyId
  658. mapCompanyInteractionItem[vsplit.CompanyId].ArticleHistoryNum += vsplit.HistoryNum
  659. mapCompanyInteractionItem[vsplit.CompanyId].ArticleCountNum += vsplit.CountNum
  660. mapCompanyInteractionItem[vsplit.CompanyId].ChartCountNum += vsplit.ChartCountNum
  661. mapCompanyInteractionItem[vsplit.CompanyId].IndustryFllowNum += vsplit.IndustryFllowNum
  662. mapCompanyInteractionItem[vsplit.CompanyId].DepartmentFollowNum += vsplit.DepartmentFollowNum
  663. mapCompanyInteractionItem[vsplit.CompanyId].KeyWordNum += vsplit.KeyWordNum
  664. mapCompanyInteractionItem[vsplit.CompanyId].ActivityOnLineNum += vsplit.OnLineNum
  665. mapCompanyInteractionItem[vsplit.CompanyId].ActivityOfficeNum += vsplit.OfficeNum
  666. mapCompanyInteractionItem[vsplit.CompanyId].ActivityNum += vsplit.OnLineNum + vsplit.OfficeNum
  667. mapCompanyInteractionItem[vsplit.CompanyId].TripNum += vsplit.TripNum
  668. mapCompanyInteractionItem[vsplit.CompanyId].RoadshowVideoNum += vsplit.RoadshowVideoNum
  669. mapCompanyInteractionItem[vsplit.CompanyId].ActivityVideoNum += vsplit.ActivityVideoNum
  670. mapCompanyInteractionItem[vsplit.CompanyId].ActivityVoiceNum += vsplit.ActivityVoiceNum
  671. mapCompanyInteractionItem[vsplit.CompanyId].RoadshowNum += vsplit.RoadshowVideoNum + vsplit.ActivityVideoNum + vsplit.ActivityVoiceNum
  672. }
  673. //如果存在就修改不存在就新增
  674. if mapUserInteraction[int(vsplit.UserId)] == 0 {
  675. itemsInteraction = append(itemsInteraction, itemInteraction)
  676. } else {
  677. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  678. if err != nil {
  679. fmt.Println("UpdateCygxUserInteractionNum Err", err)
  680. return err
  681. }
  682. fmt.Println(itemInteraction.UserId)
  683. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  684. }
  685. }
  686. }
  687. }
  688. }
  689. ////修改机构互动量信息
  690. if len(mapComapnyInteractionNum) > 0 {
  691. for k, v := range mapComapnyInteractionNum {
  692. err = models.UpdateComapanyInteractionNum(v, k)
  693. }
  694. }
  695. // 批量添加用户互动量信息
  696. if len(itemsInteraction) > 0 {
  697. _, err = models.AddCygxUserInteractionNumList(itemsInteraction)
  698. if err != nil {
  699. fmt.Println(" AddCygxUserInteractionNumList Err", err)
  700. }
  701. }
  702. // 批量添加用户互动量信息
  703. if len(mapCompanyInteractionItem) > 0 {
  704. fmt.Println("添加机构互动信息")
  705. for _, v := range mapCompanyInteractionItem {
  706. fmt.Println(v.CompanyId)
  707. if mapCompanyInteraction[v.CompanyId] > 0 {
  708. err = models.UpdateCygxCompanyInteractionNum(v)
  709. if err != nil {
  710. fmt.Println(" UpdateCygxCompanyInteractionNum Err", err)
  711. }
  712. } else {
  713. _, err = models.AddCygxCompanyInteractionNum(v)
  714. if err != nil {
  715. fmt.Println(" AddCygxCompanyInteractionNum Err", err)
  716. }
  717. }
  718. }
  719. }
  720. }
  721. return
  722. }