wx_user.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  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. updateTime := time.Now().Add(-time.Hour * 25).Format("2006-01-02 15:04:05")
  97. listUpdateUser, err := models.GetWxUserOpLogList(updateTime)
  98. if err != nil && err.Error() != utils.ErrNoRow() {
  99. return err
  100. }
  101. var userIds string
  102. var mobiles string
  103. if len(listUpdateUser) > 0 {
  104. for _, v := range listUpdateUser {
  105. userIds += strconv.Itoa(v.UserId) + ","
  106. mobiles += "'" + v.Mobile + "',"
  107. }
  108. }
  109. userIds = strings.TrimRight(userIds, ",")
  110. mobiles = strings.TrimRight(mobiles, ",")
  111. //如果用户ID不为空那么就处理这些用户的记录信息
  112. if userIds != "" {
  113. var condition string
  114. condition = ` AND user_id IN (` + userIds + `)`
  115. //处理用户的文章收藏
  116. listCollect, err := models.GetCygxArticleCollectList(condition)
  117. if err != nil && err.Error() != utils.ErrNoRow() {
  118. fmt.Println("GetAddCygxArticleCollectList ,Err" + err.Error())
  119. }
  120. if len(listCollect) > 0 {
  121. for _, v := range listCollect {
  122. user, err := models.GetWxUserItemByUserId(v.UserId)
  123. if err != nil && err.Error() != utils.ErrNoRow() {
  124. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  125. }
  126. if user != nil {
  127. fmt.Println(user.RealName)
  128. err = models.UpdateCygxArticleCollect(user)
  129. if err != nil {
  130. fmt.Println("UpdateCygxArticleCollect ,Err" + err.Error())
  131. }
  132. }
  133. }
  134. }
  135. //处理用户的文章收藏 end
  136. //修改用户关注的产业
  137. listIndustryFllow, err := models.GetCygxIndustryFllowList(condition)
  138. if err != nil {
  139. fmt.Println("GetCygxIndustryFllowList ,Err" + err.Error())
  140. }
  141. for k, v := range listIndustryFllow {
  142. if v.Mobile != "" {
  143. user, err := models.GetWxUserItemByUserId(v.UserId)
  144. if err != nil && err.Error() != utils.ErrNoRow() {
  145. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  146. }
  147. if user != nil {
  148. fmt.Println(user.RealName, k)
  149. err = models.UpdateCygxIndustryFllow(user)
  150. if err != nil {
  151. fmt.Println("UpdateCygxIndustryFllow ,Err" + err.Error())
  152. }
  153. }
  154. }
  155. }
  156. //修改用户产业关注的产业end
  157. //修改用户的阅读记录
  158. listArticlePv, err := models.GetArticleHistoryRecordAllByMobileList(condition)
  159. if err != nil {
  160. fmt.Println("GetArticleHistoryRecordAllByMobileList ,Err" + err.Error())
  161. }
  162. for k, v := range listArticlePv {
  163. if v.Mobile != "" {
  164. user, err := models.GetWxUserItemByMobile(v.Mobile)
  165. if err != nil && err.Error() != utils.ErrNoRow() {
  166. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  167. }
  168. if user != nil {
  169. fmt.Println(user.RealName, k)
  170. err = models.UpdateCygxArticleHistoryRecordAll(user)
  171. if err != nil {
  172. fmt.Println("UpdateCygxArticleCollect ,Err" + err.Error())
  173. }
  174. }
  175. }
  176. }
  177. //修改用户的阅读记录end
  178. //处理用户的搜索记录
  179. listSearch, err := models.GetCygxSearchKeyWordList(condition)
  180. if err != nil {
  181. fmt.Println("GetArticleHistoryRecordAllByMobileList ,Err" + err.Error())
  182. }
  183. for k, v := range listSearch {
  184. if v.Mobile != "" {
  185. user, err := models.GetWxUserItemByUserId(v.UserId)
  186. if err != nil && err.Error() != utils.ErrNoRow() {
  187. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  188. }
  189. if user != nil {
  190. fmt.Println(user.RealName, k)
  191. err = models.UpdateCygxSearchKeyWord(user)
  192. if err != nil {
  193. fmt.Println("UpdateCygxSearchKeyWord ,Err" + err.Error())
  194. }
  195. }
  196. }
  197. }
  198. // 处理用户的作者关注
  199. lisDepartmentF, err := models.GetArticleDepartmentFollowByMobileList(condition)
  200. if err != nil {
  201. fmt.Println("GetArticleDepartmentFollowByMobileList ,Err" + err.Error())
  202. return err
  203. }
  204. for k, v := range lisDepartmentF {
  205. if v.Mobile != "" {
  206. user, err := models.GetWxUserItemByUserId(v.UserId)
  207. if err != nil && err.Error() != utils.ErrNoRow() {
  208. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  209. }
  210. if user != nil {
  211. fmt.Println(user.RealName, k)
  212. err = models.UpdateCygxArticleDepartmentFollow(user)
  213. if err != nil {
  214. fmt.Println("UpdateCygxArticleDepartmentFollow ,Err" + err.Error())
  215. }
  216. }
  217. }
  218. }
  219. // 处理用户的作者关注end
  220. //如果手机号不为空,则更新用户的报名信息
  221. if mobiles != "" {
  222. condition = ` AND mobile IN (` + mobiles + `)`
  223. listSingUp, err := models.GetCygxActivitySignupByMobileList(condition)
  224. if err != nil {
  225. fmt.Println("GetCygxChartCollectByMobileList ,Err" + err.Error())
  226. }
  227. //fmt.Println("更新用户的报名信息长度", len(listSingUp))
  228. for _, v := range listSingUp {
  229. if v.Mobile != "" {
  230. user, err := models.GetWxUserItemByMobile(v.Mobile)
  231. if err != nil && err.Error() != utils.ErrNoRow() {
  232. fmt.Println("GetWxUserItemByUserId ,Err" + err.Error())
  233. }
  234. if user != nil {
  235. err = models.UpdateCygxActivitySignup(user)
  236. if err != nil {
  237. fmt.Println("UpdateCygxActivitySignup ,Err" + err.Error())
  238. //return err
  239. }
  240. }
  241. }
  242. }
  243. }
  244. }
  245. }
  246. //处理用户标签
  247. for _, vUser := range listUser {
  248. labels, err := models.GetCygxCompanyUserListSplit(strconv.Itoa(vUser.UserId))
  249. if err != nil {
  250. fmt.Println("GetCygxCompanyUserListSplit Err", err)
  251. return err
  252. }
  253. mapLabels := make(map[string]string)
  254. var labelsListStr []*models.UserLabel
  255. mapActivityLabels := make(map[string]string)
  256. labelsList := strings.Split(labels, ",")
  257. for _, vL := range labelsList {
  258. if mapLabels[vL] == "" && vL != "" {
  259. mapLabels[vL] = vL
  260. item := new(models.UserLabel)
  261. item.Label = vL
  262. labelsListStr = append(labelsListStr, item)
  263. }
  264. }
  265. dateTime := time.Now().AddDate(0, -3, 0).Format(utils.FormatDate)
  266. listArticlePv, err := models.GetArticlePvCount(vUser.Mobile, vUser.Email, dateTime)
  267. if err != nil && err.Error() != utils.ErrNoRow() {
  268. fmt.Println("GetArticlePvCount Err", err)
  269. return err
  270. }
  271. var articleIds string
  272. mapArticleIdLabelTotal := make(map[string]int)
  273. mapArticleIdPv := make(map[int]int)
  274. if len(listArticlePv) > 0 {
  275. for _, v := range listArticlePv {
  276. articleIds += strconv.Itoa(v.ArticleId) + ","
  277. mapArticleIdPv[v.ArticleId] = v.Pv
  278. }
  279. articleIds = strings.TrimRight(articleIds, ",")
  280. //产业、标的标签
  281. listLabelName, err := models.GetArticleGroupyIndustryName(articleIds)
  282. if err != nil && err.Error() != utils.ErrNoRow() {
  283. fmt.Println("GetArticleGroupyIndustryName Err", err)
  284. return err
  285. }
  286. if len(listLabelName) > 0 {
  287. for _, v := range listLabelName {
  288. labelsIndustryList := strings.Split(v.IndustryName, "/")
  289. labelsSubjectList := strings.Split(v.SubjectName, "/")
  290. //添加产业统计
  291. if len(labelsIndustryList) > 0 {
  292. for _, vIn := range labelsIndustryList {
  293. if mapActivityLabels[vIn] != "" {
  294. mapArticleIdLabelTotal[vIn] += mapArticleIdPv[v.ArticleId]
  295. } else {
  296. mapArticleIdLabelTotal[vIn] = mapArticleIdPv[v.ArticleId]
  297. mapActivityLabels[vIn] = vIn
  298. }
  299. }
  300. }
  301. if len(labelsSubjectList) > 0 {
  302. //添加标的统计
  303. for _, vIn := range labelsSubjectList {
  304. if mapActivityLabels[vIn] != "" {
  305. mapArticleIdLabelTotal[vIn] += mapArticleIdPv[v.ArticleId]
  306. } else {
  307. mapArticleIdLabelTotal[vIn] = mapArticleIdPv[v.ArticleId]
  308. mapActivityLabels[vIn] = vIn
  309. }
  310. }
  311. }
  312. }
  313. }
  314. }
  315. articleIds, err = models.GetCygxArticleCollectId(vUser.UserId, dateTime)
  316. if err != nil && err.Error() != utils.ErrNoRow() {
  317. fmt.Println("GetCygxArticleCollectId Err", err)
  318. return err
  319. }
  320. if articleIds != "" {
  321. //产业、标的标签
  322. listLabelName, err := models.GetArticleGroupyIndustryName(articleIds)
  323. if err != nil && err.Error() != utils.ErrNoRow() {
  324. fmt.Println("GetArticleGroupyIndustryName Err", err)
  325. return err
  326. }
  327. if len(listLabelName) > 0 {
  328. for _, v := range listLabelName {
  329. labelsIndustryList := strings.Split(v.IndustryName, "/")
  330. labelsSubjectList := strings.Split(v.SubjectName, "/")
  331. //添加产业统计
  332. if len(labelsIndustryList) > 0 {
  333. for _, vIn := range labelsIndustryList {
  334. if mapActivityLabels[vIn] != "" {
  335. mapArticleIdLabelTotal[vIn] += 1
  336. } else {
  337. mapArticleIdLabelTotal[vIn] = 1
  338. mapActivityLabels[vIn] = vIn
  339. }
  340. }
  341. }
  342. if len(labelsSubjectList) > 0 {
  343. //添加标的统计
  344. for _, vIn := range labelsSubjectList {
  345. if mapActivityLabels[vIn] != "" {
  346. mapArticleIdLabelTotal[vIn] += 1
  347. } else {
  348. mapArticleIdLabelTotal[vIn] = 1
  349. mapActivityLabels[vIn] = vIn
  350. }
  351. }
  352. }
  353. }
  354. }
  355. }
  356. //活动标签计算
  357. listActivityPv, err := models.GetActivitySignCount(vUser.Mobile, dateTime)
  358. if err != nil && err.Error() != utils.ErrNoRow() {
  359. fmt.Println("GetActivitySignCount Err", err)
  360. return err
  361. }
  362. if len(listActivityPv) > 0 {
  363. for _, v := range listActivityPv {
  364. labelsList := strings.Split(v.Label, "-")
  365. for _, v2 := range labelsList {
  366. labelsListSon := strings.Split(v2, "/")
  367. for _, v3 := range labelsListSon {
  368. if mapActivityLabels[v3] != "" {
  369. mapArticleIdLabelTotal[v3] += 1
  370. } else {
  371. mapArticleIdLabelTotal[v3] = 1
  372. mapActivityLabels[v3] = v3
  373. }
  374. }
  375. }
  376. }
  377. }
  378. //对标签数量进行排序
  379. type KvPair struct {
  380. Key string
  381. Val int
  382. }
  383. tmpList := make([]KvPair, 0)
  384. for k, v := range mapArticleIdLabelTotal {
  385. tmpList = append(tmpList, KvPair{Key: k, Val: v})
  386. }
  387. sort.Slice(tmpList, func(i, j int) bool {
  388. return tmpList[i].Val > tmpList[j].Val // 降序
  389. })
  390. for _, v := range tmpList {
  391. if v.Key != "" {
  392. mapLabels[v.Key] = v.Key
  393. item := new(models.UserLabel)
  394. item.Label = v.Key
  395. labelsListStr = append(labelsListStr, item)
  396. }
  397. }
  398. var labelNew string
  399. for _, v := range labelsListStr {
  400. labelNew += v.Label + ","
  401. }
  402. labelNew = strings.TrimRight(labelNew, ",")
  403. if labelNew != "" {
  404. err = models.UpdateUserLabel(labelNew, vUser.UserId)
  405. if err != nil {
  406. fmt.Println("UpdateUserLabel Err", err)
  407. return err
  408. }
  409. }
  410. }
  411. //处理用户、机构互动量数据
  412. {
  413. var userIds string
  414. var itemsInteraction []*models.CygxUserInteractionNum
  415. mapUserInteraction := make(map[int]int)
  416. //获取已经处理记录的用户并记录切片
  417. listUserInteractionNum, err := models.GetCygxUserInteractionNumList()
  418. if err != nil && err.Error() != utils.ErrNoRow() {
  419. fmt.Println("GetCygxUserInteractionNumList Err", err)
  420. return err
  421. }
  422. for _, v := range listUserInteractionNum {
  423. mapUserInteraction[v.UserId] = v.UserId
  424. }
  425. //处理用户互动量数据
  426. for kUser, vUser := range listUser {
  427. userIds += strconv.Itoa(vUser.UserId) + ","
  428. //一次查询一百个避免用户过多
  429. if kUser%100 == 0 {
  430. userIds = strings.TrimRight(userIds, ",")
  431. userUserInteractionList, err := models.GetCygxCompanyUserUserInteraction(userIds)
  432. if err != nil {
  433. fmt.Println("GetCygxCompanyUserUserInteraction Err", err)
  434. return err
  435. }
  436. //处理用户的互动量
  437. if len(userUserInteractionList) > 0 {
  438. for _, vsplit := range userUserInteractionList {
  439. interactionNum = vsplit.HistoryNum + vsplit.CountNum + vsplit.IndustryFllowNum + vsplit.DepartmentFollowNum + vsplit.KeyWordNum + vsplit.OnLineNum + vsplit.OfficeNum + vsplit.ChartCountNum
  440. if interactionNum > 0 {
  441. //更改用户的互动量
  442. err = models.UpdateUserInteractionNum(interactionNum, int(vsplit.UserId))
  443. if err != nil {
  444. fmt.Println("UpdateUserInteractionNum Err", err)
  445. return err
  446. }
  447. mapComapnyInteractionNum[vsplit.CompanyId] += interactionNum
  448. itemInteraction := new(models.CygxUserInteractionNum)
  449. itemInteraction.UserId = int(vsplit.UserId)
  450. itemInteraction.ArticleHistoryNum = vsplit.HistoryNum
  451. itemInteraction.ArticleCountNum = vsplit.CountNum
  452. itemInteraction.ChartCountNum = vsplit.ChartCountNum
  453. itemInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  454. itemInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  455. itemInteraction.KeyWordNum = vsplit.KeyWordNum
  456. itemInteraction.ActivityOnLineNum = vsplit.OnLineNum
  457. itemInteraction.ActivityOfficeNum = vsplit.OfficeNum
  458. itemInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  459. itemInteraction.CreateTime = time.Now()
  460. itemInteraction.ModifyTime = time.Now()
  461. //如果存在就修改不存在就新增
  462. if mapUserInteraction[int(vsplit.UserId)] == 0 {
  463. itemsInteraction = append(itemsInteraction, itemInteraction)
  464. } else {
  465. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  466. if err != nil {
  467. fmt.Println("UpdateCygxUserInteractionNum Err", err)
  468. return err
  469. }
  470. fmt.Println(itemInteraction.UserId)
  471. }
  472. }
  473. }
  474. }
  475. userIds = ""
  476. }
  477. }
  478. userIds = strings.TrimRight(userIds, ",")
  479. if userIds != "" {
  480. userUserInteractionList, err := models.GetCygxCompanyUserUserInteraction(userIds)
  481. if err != nil {
  482. fmt.Println("GetCygxCompanyUserUserInteraction Err", err)
  483. return err
  484. }
  485. //fmt.Println("处理用户剩余的")
  486. //处理用户的互动量
  487. if len(userUserInteractionList) > 0 {
  488. for _, vsplit := range userUserInteractionList {
  489. interactionNum = vsplit.HistoryNum + vsplit.CountNum + vsplit.IndustryFllowNum + vsplit.DepartmentFollowNum + vsplit.KeyWordNum + vsplit.OnLineNum + vsplit.OfficeNum + vsplit.ChartCountNum
  490. if interactionNum > 0 {
  491. err = models.UpdateUserInteractionNum(interactionNum, int(vsplit.UserId))
  492. if err != nil {
  493. fmt.Println("UpdateUserInteractionNum Err", err)
  494. return err
  495. }
  496. mapComapnyInteractionNum[vsplit.CompanyId] += interactionNum
  497. itemInteraction := new(models.CygxUserInteractionNum)
  498. itemInteraction.UserId = int(vsplit.UserId)
  499. itemInteraction.ArticleHistoryNum = vsplit.HistoryNum
  500. itemInteraction.ArticleCountNum = vsplit.CountNum
  501. itemInteraction.ChartCountNum = vsplit.ChartCountNum
  502. itemInteraction.IndustryFllowNum = vsplit.IndustryFllowNum
  503. itemInteraction.DepartmentFollowNum = vsplit.DepartmentFollowNum
  504. itemInteraction.KeyWordNum = vsplit.KeyWordNum
  505. itemInteraction.ActivityOnLineNum = vsplit.OnLineNum
  506. itemInteraction.ActivityOfficeNum = vsplit.OfficeNum
  507. itemInteraction.ActivityNum = vsplit.OnLineNum + vsplit.OfficeNum
  508. itemInteraction.CreateTime = time.Now()
  509. itemInteraction.ModifyTime = time.Now()
  510. //如果存在就修改不存在就新增
  511. if mapUserInteraction[int(vsplit.UserId)] == 0 {
  512. itemsInteraction = append(itemsInteraction, itemInteraction)
  513. } else {
  514. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  515. if err != nil {
  516. fmt.Println("UpdateCygxUserInteractionNum Err", err)
  517. return err
  518. }
  519. fmt.Println(itemInteraction.UserId)
  520. err = models.UpdateCygxUserInteractionNum(itemInteraction)
  521. }
  522. }
  523. }
  524. }
  525. }
  526. ////修改机构互动量信息
  527. if len(mapComapnyInteractionNum) > 0 {
  528. for k, v := range mapComapnyInteractionNum {
  529. err = models.UpdateComapanyInteractionNum(v, k)
  530. }
  531. }
  532. // 批量添加用户互动量信息
  533. if len(itemsInteraction) > 0 {
  534. _, err = models.AddCygxUserInteractionNumList(itemsInteraction)
  535. if err != nil {
  536. fmt.Println(" RemoveChartCollectByMobile Err", err)
  537. }
  538. }
  539. }
  540. return
  541. }