main.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. package main
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "log"
  6. "strings"
  7. "sync"
  8. "unicode"
  9. "github.com/xuri/excelize/v2"
  10. util "jygit.jydev.jianyu360.cn/data_processing/common_utils"
  11. "jygit.jydev.jianyu360.cn/data_processing/common_utils/elastic"
  12. "jygit.jydev.jianyu360.cn/data_processing/common_utils/mongodb"
  13. )
  14. var (
  15. // JianZhiLabel = make([]CreditLabel, 0)
  16. ZhimaMap = map[string]string{}
  17. MgoT *mongodb.MongodbSim //测试环境链接
  18. Es *elastic.Elastic
  19. )
  20. func Init() {
  21. f, err := excelize.OpenFile("./jianyu_zhima_0829.xlsx")
  22. if err != nil {
  23. fmt.Println(err)
  24. return
  25. }
  26. defer func() {
  27. f.Save()
  28. if err := f.Close(); err != nil {
  29. fmt.Println(err)
  30. }
  31. }()
  32. //2.专项债详情
  33. rows, err := f.GetRows("0829")
  34. if err != nil {
  35. fmt.Println(err)
  36. return
  37. }
  38. for i := 1; i < len(rows); i++ {
  39. // data := CreditLabel{
  40. // ZhimaToptype: rows[i][0],
  41. // ZhimaSubtype: rows[i][1],
  42. // ZhimaName: rows[i][2],
  43. // ZhimaValue: rows[i][4],
  44. // }
  45. // JianZhiLabel = append(JianZhiLabel, data)
  46. ZhimaMap[rows[i][2]] = rows[i][1]
  47. }
  48. //测试环境
  49. MgoT = &mongodb.MongodbSim{
  50. MongodbAddr: "192.168.3.149:27102",
  51. //MongodbAddr: "192.168.3.206:27002",
  52. DbName: "mixdata",
  53. Size: 10,
  54. UserName: "root",
  55. Password: "root",
  56. // Direct: true,
  57. }
  58. MgoT.InitPool()
  59. //测试环境es
  60. Es = &elastic.Elastic{
  61. S_esurl: "http://192.168.3.149:9201",
  62. //S_esurl: "http://172.17.4.184:19805",
  63. I_size: 10,
  64. Username: "",
  65. Password: "",
  66. }
  67. Es.InitElasticSize()
  68. //正式环境
  69. // MgoT = &mongodb.MongodbSim{
  70. // MongodbAddr: "172.17.189.140:27080",
  71. // //MongodbAddr: "127.0.0.1:27083",
  72. // Size: 10,
  73. // DbName: "mixdata",
  74. // UserName: "SJZY_RWbid_ES",
  75. // Password: "SJZY@B4i4D5e6S",
  76. // //Direct: true,
  77. // }
  78. // MgoT.InitPool()
  79. // Es = &elastic.Elastic{
  80. // //S_esurl: "http://127.0.0.1:19908",
  81. // S_esurl: "http://172.17.4.184:19908",
  82. // I_size: 10,
  83. // Username: "jybid",
  84. // Password: "Top2023_JEB01i@31",
  85. // }
  86. // Es.InitElasticSize()
  87. }
  88. func main() {
  89. Init()
  90. appID := "2021003111633206"
  91. privateKeyPEM := "-----BEGIN RSA PRIVATE KEY-----\nMIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCaJnmz3N1Z43jxtmZJmPkInl3FbfudxjicThHj+Hkndp+muzZXlAPcWoYTFLAfVa6xg9xAc58fWTPUGOpouh0ZDEP8TGvD784AljDNwRXPI9+afjcxN8gzsNPlqA6KVkAu5u5uEI1HHQgtdyRoCEnXgQRXj6DqAs9olbx8HrTxHjZzjPd+HXv+v4na3zAvZsvPdhLB2ggpVW6uQN7ur8C+hVpB3ZO+gGVFHy3m1t08XgscljyOA9Vpk4T8TnKZqDvnI6ehWFCGeD11yoe3ipHJJdP/+u9/tXiKhm29mJvcM9C6gab6BOQABByQPb2nPFFyfPglbRYrYxgKp/eXUQTzAgMBAAECggEAO6BCVyZJoKlycNzC+Bjpy0Gmt+Vw/HheEWfJV8sW4gLqgk3MGVgxnhyN2/eWoKg96IA+w9d1Z2TTvWjd0yCafMPX0FGnJaUuo990hUH4s6UGqvXDV5BiKkxtylmVNkFilkHRXFWesDE0ppF9TZhXJ7rJ+Syfa6UmoSe6PrCKAPG4FD8MH1ODj5b42l/TRIFM948nTtTLFAFgd77P5ULBCKVfBB5V9XdKhLRdwG9RxugWwkxuCiMOtmk45DzA/PQgvkIzEViD/2NJX67/S88B0G63zdQizJrvxsLp9fThmjhlo/+CaF+a+nfIzg81TfQHlRuTjiYc7iE9n5K0sU82wQKBgQDydI9pEjkPH+ZEixEymdx8D4workBfa+GXgobJ2UwatqCJOCYqZJR0MhjTVeDJiiTGFiemNyZHT0WFQedAQ/O9mkRf0MRhzR6ZOiMnCG5pSSOKdmQXoqjOqcMzdgWBQRol0eLB/vto8M3bpt1VautR0qQOR7BrFsj57K3asofikQKBgQCiwwie5gyCAYB1gkp4QkLmQDSTJdZaTlzzx2oa2/ZB4Pg6wWWNJIxEfSwtuGVH4jGJl0Eer2YpHzaY7f2NfOWJCpNI/aRhM/RilQsFXTox/5bqlbAfspPMqSHnry2OgbZb9CRF3jH7kt65390SKde4A4JNE+jJ0Xb07Tzcr7+pQwKBgCDJ8KcWBs9r0flNEVtVgYLpm1vZDO2aqlySE2Zy0579OcK07Dxpc8YvDDpwb8DxxL1hO6V36d5U8yLtYbfIOMtYdIy8sAJF+jBgs2ZQ9pWYhYzxK+IiZk/kl3h7Ko1rX3zj4JW5xQhRIJXnACHQHtjm8rbXrR0ebLmX738XC9dxAoGAQfUDQ1E6dFyjb/syrnU7ow8VvyOwL7xd0rRW/TdyHdRLA5Rn0MCkzwRiqMx2zqCNLpLK4uJ1ZeiuOV8IRxP7+IL+mK+gs3tYZ7K6Wpwi/yvyPnIWg2Hcny1S/g5xSbSq76yKHn4ihy5Hb8+WSMwIDRvu68lLpq1ppWuWJGBcLP0CgYAnGtHlFY887zSI0aRdzV3EYm/sPnmYy0TWIUVLuGL8kkprcSIW2yRxx1GtpB+3A7cPu61WwRbiswJA6VmQHvn8f9ds81+aiO5KQLMk4MbrTwWhWLDpP4BxjWANVzPr19ZwmDJcYkh7YUI2iLqH7dXho5k62OYCM1T53xlql6HDcg==\n-----END RSA PRIVATE KEY-----"
  92. //epCertNo := "914400007211976169" //对应企业库 credit_no
  93. sceneCode := "JIANYU_LABEL"
  94. //1.查询qyxy 数据
  95. defer util.Catch()
  96. sess := MgoT.GetMgoConn()
  97. defer MgoT.DestoryMongoConn(sess)
  98. it := sess.DB("mixdata").C("qyxy_std").Find(nil).Sort("_id").Iter()
  99. fmt.Println("taskRun 开始")
  100. count := 0
  101. ch := make(chan bool, 5)
  102. wg := &sync.WaitGroup{}
  103. for tmp := make(map[string]interface{}); it.Next(&tmp); count++ {
  104. if count%1000 == 0 {
  105. log.Println("current", count)
  106. }
  107. // 存在芝麻标签,直接跳过
  108. //if _, ok := tmp["zhima_labels"]; ok {
  109. // continue
  110. //}
  111. if util.ObjToString(tmp["credit_no"]) == "" {
  112. continue
  113. }
  114. if util.ObjToString(tmp["company_type"]) == "个体工商户" {
  115. continue
  116. }
  117. ch <- true
  118. wg.Add(1)
  119. go func(tmp map[string]interface{}) {
  120. defer func() {
  121. <-ch
  122. wg.Done()
  123. }()
  124. //
  125. id := mongodb.BsonIdToSId(tmp["_id"])
  126. epCertNo := util.ObjToString(tmp["credit_no"])
  127. createLabels := getCreditLabel(appID, privateKeyPEM, epCertNo, sceneCode)
  128. if len(createLabels) > 0 {
  129. updateEs := map[string]interface{}{
  130. "zhima_labels": convertToInterfaceSliceEs(createLabels),
  131. }
  132. updateMgo := map[string]interface{}{
  133. "zhima_labels": convertToInterfaceSliceMgo(createLabels),
  134. }
  135. where := map[string]interface{}{
  136. "_id": tmp["_id"],
  137. }
  138. MgoT.Update("qyxy_std", where, map[string]interface{}{"$set": updateMgo}, true, false)
  139. err := Es.UpdateDocument("qyxy", id, updateEs)
  140. if err != nil && err.Error() != "Document not updated: noop" {
  141. log.Println("qyxy es update err", err, id)
  142. } else {
  143. log.Println("ID ", id)
  144. }
  145. }
  146. }(tmp)
  147. tmp = make(map[string]interface{})
  148. }
  149. wg.Wait()
  150. log.Println("企业芝麻标签结束")
  151. }
  152. // getCreditLabel 获取芝麻企业信用企业标签
  153. func getCreditLabel(appID, privateKeyPEM, certNo, sceneCode string) (createLabels []CreditLabel) {
  154. BizContent := BizContentForLabelQuery{
  155. EPCertNo: certNo,
  156. ShowFlag: true,
  157. SceneCode: sceneCode,
  158. }
  159. curl := "https://openapi.alipay.com/gateway.do"
  160. method := "zhima.credit.ep.acceptance.label.query"
  161. bizbyte, _ := json.Marshal(BizContent)
  162. priKey, err := parsePrivateKey(privateKeyPEM)
  163. if err != nil {
  164. log.Fatalln("parsePrivateKey err", err)
  165. }
  166. resMap, err := DoRequest(appID, string(bizbyte), curl, method, priKey)
  167. if err != nil {
  168. log.Fatalln("request err", err)
  169. }
  170. responseData := util.ObjToMap((*resMap)["zhima_credit_ep_acceptance_label_query_response"])
  171. if util.ObjToString(((*responseData)["code"])) == "10000" && util.ObjToString(((*responseData)["msg"])) == "Success" {
  172. if (*responseData)["label_content"] == nil {
  173. //log.Println("请求出错,没有返回企业标签内容模型", BizContent)
  174. } else {
  175. if labelContent, ok := (*responseData)["label_content"].([]interface{}); ok {
  176. for _, v := range labelContent {
  177. label := util.ObjToMap(v)
  178. labelName := util.ObjToString((*label)["label_name"]) //外显
  179. labelCategory := util.ObjToString((*label)["label_category"]) //一级分类
  180. labelCode := util.ObjToString((*label)["label_code"])
  181. labelDe := util.ObjToString((*label)["label_definition"])
  182. newName, subtype := getLabel(labelName)
  183. // log.Println("newName,subtype ", newName, subtype)
  184. data := CreditLabel{}
  185. data.ZhimaCode = labelCode
  186. data.ZhimaDefinition = labelDe
  187. data.ZhimaToptype = labelCategory
  188. data.ZhimaSubtype = subtype
  189. data.ZhimaName = newName
  190. data.ZhimaValue = labelName
  191. // if subtype != "" {
  192. createLabels = append(createLabels, data)
  193. // }
  194. }
  195. }
  196. }
  197. } else {
  198. log.Println("请求失败", BizContent, (*responseData))
  199. }
  200. return
  201. }
  202. // getLabel 根据labelTop labelName 获取对应芝麻标签
  203. func getLabel(labelName string) (newName, subtype string) {
  204. // for _, v := range JianZhiLabel {
  205. // if v.ZhimaToptype == labelTop && v.ZhimaName == labelName {
  206. // return v
  207. // }
  208. // }
  209. newName = getNewName(labelName)
  210. // log.Println("old ", labelName, " new ", newName)
  211. subtype = ""
  212. if ZhimaMap[newName] != "" {
  213. subtype = ZhimaMap[newName]
  214. }
  215. return
  216. }
  217. func getNewName(name string) string {
  218. if strings.Contains(name, "年企业信用") {
  219. return "芝麻企业信用等级连续情况"
  220. } else if strings.Contains(name, "芝麻企业信用等级") {
  221. return "芝麻企业信用等级"
  222. } else if strings.Contains(name, "企业信用等级") {
  223. return "企业信用等级_个体"
  224. } else if strings.Contains(name, "公开项目中标") {
  225. return "年度公开项目中标"
  226. } else if ZhimaMap[name] != "" {
  227. return name
  228. } else if strings.Contains(name, "年A级纳税人") {
  229. return "A级纳税人连续年限"
  230. } else if strings.Contains(name, "年A级纳税人") {
  231. return "A级纳税人连续年限"
  232. } else if strings.Contains(name, "融资") && strings.Contains(name, "获") {
  233. return "获得融资"
  234. } else if strings.Contains(name, "融资") && strings.Contains(name, "轮") {
  235. return "融资轮次"
  236. } else if strings.Contains(name, "年网络销量前") && strings.Contains(name, "%") {
  237. return "年度网络销量靠前_百分比"
  238. } else if strings.Contains(name, "季度网络销量前") && strings.Contains(name, "%") {
  239. return "季度网络销量靠前_百分比"
  240. } else if strings.Contains(name, "月销量全网前") && strings.Contains(name, "%") {
  241. return "月度网络销量靠前_百分比"
  242. } else if strings.Contains(name, "年网络销量前") {
  243. return "年度网络销量靠前"
  244. } else if strings.Contains(name, "季度网络销量前") {
  245. return "季度网络销量靠前"
  246. } else if strings.Contains(name, "月销量全网前") {
  247. return "月度网络销量靠前"
  248. } else if strings.Contains(name, "绝对控股") {
  249. return "绝对控股公司数"
  250. } else if strings.Contains(name, "拥有") && strings.Contains(name, "作品") {
  251. return "拥有作品"
  252. } else if strings.Contains(name, "拥有") && strings.Contains(name, "著作权") {
  253. return "拥有软件著作权"
  254. } else if strings.Contains(name, "作品创作量位于同行业TOP") {
  255. return "作品创作量位于同行业TOP数"
  256. } else if strings.Contains(name, "作品创作量位于同行业前") {
  257. return "作品创作量位于同行业TOP"
  258. } else if strings.Contains(name, "年作品创作量极速增长") && strings.Contains(name, "连续") {
  259. return "作品创作量极速增长连续年"
  260. } else if strings.Contains(name, "年作品创作量增长") && strings.Contains(name, "连续") {
  261. return "作品创作量增长连续年"
  262. } else if strings.Contains(name, "个月作品创作量增长") && strings.Contains(name, "连续") {
  263. return "作品创作量增长连续月"
  264. } else if strings.Contains(name, "年软件研发量增长") && strings.Contains(name, "连续") {
  265. return "软件研发量增长连续年"
  266. } else if strings.Contains(name, "个月软件研发量增长") && strings.Contains(name, "连续") {
  267. return "软件研发量增长连续月"
  268. } else if strings.Contains(name, "货架商品数同行前") {
  269. return "货架商品数位于同行TOP"
  270. } else if strings.Contains(name, "类目直播销量前") && strings.Contains(name, "%") {
  271. return "直播带货销量位于平台TOP"
  272. } else if strings.Contains(name, "类目直播销量前") {
  273. return "直播带货销量位于平台TOP数"
  274. } else if strings.Contains(name, "个月直播销量增长") && strings.Contains(name, "连续") {
  275. return "直播带货销量增长连续月"
  276. } else if strings.Contains(name, "类目短视频销量平台前") && strings.Contains(name, "%") {
  277. return "短视频带货销量位于平台TOP"
  278. } else if strings.Contains(name, "类目短视频销量平台前") {
  279. return "短视频带货销量位于平台TOP数"
  280. } else if strings.Contains(name, "个月短视频销量增长") && strings.Contains(name, "连续") {
  281. return "短视频带货销量增长连续月"
  282. } else if strings.Contains(name, "年度网络销量同行前") && strings.Contains(name, "%") {
  283. return "年度网络销量位于同行TOP"
  284. } else if strings.Contains(name, "季度网络销量同行前") && strings.Contains(name, "%") {
  285. return "季度网络销量位于同行TOP"
  286. } else if strings.Contains(name, "月网络销量同行前") && strings.Contains(name, "%") {
  287. return "月网络销量位于同行TOP"
  288. } else if strings.Contains(name, "年度网络销量同行前") {
  289. return "年度网络销量位于同行TOP数"
  290. } else if strings.Contains(name, "季度网络销量同行前") {
  291. return "季度网络销量位于同行TOP数"
  292. } else if strings.Contains(name, "月网络销量同行前") {
  293. return "月网络销量位于同行TOP数"
  294. }
  295. strs := RemoveNumbers(name)
  296. strs = RemoveSpecialChars(strs)
  297. strs = strings.ReplaceAll(strs, "前", "")
  298. for k, _ := range ZhimaMap {
  299. if strings.Contains(name, k) {
  300. return k
  301. }
  302. if strings.Contains(k, name) {
  303. return k
  304. }
  305. isOk := true
  306. for _, v := range strings.Split(strs, "年") {
  307. if !strings.Contains(k, v) && v != "" {
  308. isOk = false
  309. }
  310. }
  311. if isOk {
  312. return k
  313. }
  314. }
  315. return ""
  316. }
  317. // RemoveSpecialChars 去除字符串中的特定字符,如%、「、」
  318. func RemoveSpecialChars(s string) string {
  319. var sb strings.Builder
  320. for _, r := range s {
  321. // 检查字符是否不是%、「或」
  322. // 注意:「的Unicode码点是0x300C,」的Unicode码点是0x300D
  323. if r != '%' && r != rune(0x300C) && r != rune(0x300D) {
  324. sb.WriteRune(r)
  325. }
  326. }
  327. return sb.String()
  328. }
  329. // RemoveNumbers 从字符串中移除所有数字
  330. func RemoveNumbers(s string) string {
  331. var sb strings.Builder
  332. for _, r := range s {
  333. if !unicode.IsDigit(r) {
  334. sb.WriteRune(r)
  335. }
  336. }
  337. return sb.String()
  338. }
  339. func convertToInterfaceSliceEs(labels []CreditLabel) []map[string]interface{} {
  340. result := make([]map[string]interface{}, len(labels))
  341. for i, label := range labels {
  342. result[i] = map[string]interface{}{
  343. "zhima_toptype": label.ZhimaToptype,
  344. "zhima_subtype": label.ZhimaSubtype,
  345. "zhima_name": label.ZhimaName,
  346. "zhima_definition": label.ZhimaDefinition,
  347. "zhima_value": label.ZhimaValue,
  348. }
  349. }
  350. return result
  351. }
  352. func convertToInterfaceSliceMgo(labels []CreditLabel) []map[string]interface{} {
  353. result := make([]map[string]interface{}, len(labels))
  354. for i, label := range labels {
  355. result[i] = map[string]interface{}{
  356. "zhima_toptype": label.ZhimaToptype,
  357. "zhima_subtype": label.ZhimaSubtype,
  358. "zhima_name": label.ZhimaName,
  359. "zhima_code": label.ZhimaCode,
  360. "zhima_definition": label.ZhimaDefinition,
  361. "zhima_value": label.ZhimaValue,
  362. }
  363. }
  364. return result
  365. }