commodity_coal_mine.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. package services
  2. import (
  3. "fmt"
  4. "github.com/mozillazg/go-pinyin"
  5. "github.com/tealeg/xlsx"
  6. "hongze/hongze_data_crawler/models"
  7. "hongze/hongze_data_crawler/utils"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. func FileCoalJsm() () {
  13. var err error
  14. defer func() {
  15. if err != nil {
  16. fmt.Println("RefreshDataFromCoalJsm Err:" + err.Error())
  17. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromCoalJsm ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  18. }
  19. }()
  20. //path := "static/file/442家晋陕蒙煤矿周度产量数据-20220328.xlsx"
  21. path := "/home/code/python/coal_mail/emailFile/442家晋陕蒙煤矿周度产量数据-%s.xlsx"
  22. path = fmt.Sprintf(path,time.Now().Format(utils.FormatDateUnSpace))
  23. //exist,err := PathExists(path)
  24. //if err != nil {
  25. // fmt.Println(err)
  26. // return
  27. //}
  28. xlFile, err := xlsx.OpenFile(path)
  29. if err != nil {
  30. return
  31. }
  32. //var xlFile *xlsx.File
  33. //if exist {
  34. // xlFile, err = xlsx.OpenFile(path)
  35. // if err != nil {
  36. // return
  37. // }
  38. //}else {
  39. // return
  40. //}
  41. var province string
  42. var description string
  43. var exchange string
  44. var city string
  45. var companyName string
  46. var group string
  47. var dateMap = make(map[int]string)
  48. var codeMap = make(map[string]string)
  49. var indexMap = make(map[string]string)
  50. var codeCompanyMap = make(map[string]string)
  51. var indexCompanyMap = make(map[string]string)
  52. var items []*models.BaseFromCoalmineMapping
  53. var itemsCompany []*models.BaseFromCoalmineMapping
  54. var itemsIndex []*models.BaseFromCoalmineJsmIndex
  55. var itemsCompanyIndex []*models.BaseFromCoalmineCompanyIndex
  56. codeList, err := models.GetBaseFromCoalmineMapping()
  57. if err != nil && err.Error() != utils.ErrNoRow() {
  58. utils.FileLog.Info("获取煤炭指标失败:", err)
  59. return
  60. }
  61. if len(codeList) > 0 {
  62. for _, v := range codeList {
  63. codeMap[v.IndexName] = v.IndexCode
  64. }
  65. }
  66. codeCompanyList, err := models.GetBaseFromCoalmineMapping()
  67. if err != nil && err.Error() != utils.ErrNoRow() {
  68. utils.FileLog.Info("获取煤炭公司指标失败:", err)
  69. return
  70. }
  71. if len(codeCompanyList) > 0 {
  72. for _, v := range codeCompanyList {
  73. codeCompanyMap[v.IndexName] = v.IndexCode
  74. }
  75. }
  76. indexList, err := models.GetBaseFromCoalmineIndex()
  77. if err != nil && err.Error() != utils.ErrNoRow() {
  78. utils.FileLog.Info("获取煤炭公司指标失败:", err)
  79. return
  80. }
  81. if len(indexList) > 0 {
  82. for _, v := range indexList {
  83. indexMap[v.IndexName+v.DataTime] = v.DealValue
  84. }
  85. }
  86. indexCompanyList, err := models.GetBaseFromCoalmineCompanyIndex()
  87. if err != nil && err.Error() != utils.ErrNoRow() {
  88. utils.FileLog.Info("获取煤炭公司指标失败:", err)
  89. return
  90. }
  91. if len(indexCompanyList) > 0 {
  92. for _, v := range indexCompanyList {
  93. indexCompanyMap[v.IndexName+v.DataTime] = v.DealValue
  94. }
  95. }
  96. for _, sheet := range xlFile.Sheets {
  97. //遍历行读取
  98. maxRow := sheet.MaxRow
  99. for i := 0; i < maxRow; i++ {
  100. //获取样本情况
  101. if i > 3 && i < 16 {
  102. row := sheet.Row(i)
  103. cells := row.Cells
  104. Loop2:
  105. for k, cell := range cells {
  106. text := cell.String()
  107. if text != "" {
  108. if k == 1 {
  109. province = text
  110. }
  111. if k == 3 {
  112. description = text
  113. }
  114. if k == 4 {
  115. item := new(models.BaseFromCoalmineMapping)
  116. exchange = text
  117. exists := ContainsSpecialName(province)
  118. var strResult string
  119. if exists {
  120. abbr := TrimProvinceName(province)
  121. //取处理后公司名首字母缩写
  122. a := pinyin.NewArgs()
  123. rows := pinyin.Pinyin(exchange, a)
  124. for i := 0; i < len(rows); i++ {
  125. if len(rows[i]) != 0 {
  126. str := rows[i][0]
  127. pi := str[0:1]
  128. strResult += pi
  129. }
  130. }
  131. item.IndexCode = abbr + strResult + "jsm"
  132. } else {
  133. //取处理后公司名首字母缩写
  134. a := pinyin.NewArgs()
  135. rows := pinyin.Pinyin(province+exchange, a)
  136. for i := 0; i < len(rows); i++ {
  137. if len(rows[i]) != 0 {
  138. str := rows[i][0]
  139. pi := str[0:1]
  140. strResult += pi
  141. }
  142. }
  143. item.IndexCode = strResult + "jsm"
  144. }
  145. item.IndexName = province + exchange
  146. item.CreateTime = time.Now()
  147. items = append(items, item)
  148. break Loop2
  149. }
  150. }
  151. }
  152. }
  153. //获取日期
  154. if i == 3 {
  155. row := sheet.Row(i)
  156. cells := row.Cells
  157. for k, cell := range cells {
  158. text := cell.String()
  159. stamp, _ := time.ParseInLocation("01-02-06", text, time.Now().Location())
  160. if k > 4 {
  161. dateMap[k] = stamp.Format(utils.FormatDate)
  162. }
  163. }
  164. }
  165. //获取具体产量
  166. if i > 3 && i < 16 {
  167. row := sheet.Row(i)
  168. cells := row.Cells
  169. for k, cell := range cells {
  170. text := cell.String()
  171. if k > 4 {
  172. item := new(models.BaseFromCoalmineJsmIndex)
  173. item.IndexName = province + exchange
  174. item.IndexCode = codeMap[item.IndexName]
  175. item.Exchange = exchange
  176. item.DealValue = text
  177. item.DataTime = dateMap[k]
  178. item.Exchange = exchange
  179. item.Description = description
  180. item.Province = province
  181. item.Source = "三省周度"
  182. if exchange == "产量"{
  183. item.Unit = "万吨"
  184. }else {
  185. item.Unit = "百分比"
  186. }
  187. item.Frequency = "周度"
  188. item.ModifyTime = time.Now()
  189. item.CreateTime = time.Now()
  190. itemsIndex = append(itemsIndex, item)
  191. }
  192. }
  193. }
  194. //获取公司指标名称
  195. if i > 17 {
  196. row := sheet.Row(i)
  197. cells := row.Cells
  198. Loop3:
  199. for k, cell := range cells {
  200. text := cell.String()
  201. if text != "" {
  202. if k == 1 {
  203. province = text
  204. }
  205. if k == 2 {
  206. city = text
  207. }
  208. if k == 3 {
  209. companyName = text
  210. }
  211. if k == 4 {
  212. item := new(models.BaseFromCoalmineMapping)
  213. group = text
  214. trimName := TrimCompanyName(companyName)
  215. item.IndexName = trimName
  216. //取处理后公司名首字母缩写
  217. strResult := ""
  218. a := pinyin.NewArgs()
  219. rows := pinyin.Pinyin(trimName, a)
  220. for i := 0; i < len(rows); i++ {
  221. if len(rows[i]) != 0 {
  222. str := rows[i][0]
  223. pi := str[0:1]
  224. strResult += pi
  225. }
  226. }
  227. item.IndexCode = strResult + "company"
  228. item.CreateTime = time.Now()
  229. itemsCompany = append(itemsCompany, item)
  230. break Loop3
  231. }
  232. }
  233. }
  234. }
  235. //获取公司具体产量
  236. if i > 18 {
  237. row := sheet.Row(i)
  238. cells := row.Cells
  239. for k, cell := range cells {
  240. text := cell.String()
  241. if k > 4 {
  242. item := new(models.BaseFromCoalmineCompanyIndex)
  243. companyName = TrimCompanyName(companyName)
  244. item.IndexName = companyName
  245. item.IndexCode = codeCompanyMap[item.IndexName]
  246. item.DealValue = text
  247. item.DataTime = dateMap[k]
  248. item.Province = province
  249. item.City = city
  250. //处理无类别名时的情况
  251. if group == "无" {
  252. item.GroupName = companyName
  253. } else {
  254. item.GroupName = group
  255. }
  256. item.Source = "三省企业"
  257. item.Unit = "万吨"
  258. item.Frequency = "周度"
  259. item.ModifyTime = time.Now()
  260. item.CreateTime = time.Now()
  261. //fmt.Println(item)
  262. itemsCompanyIndex = append(itemsCompanyIndex, item)
  263. }
  264. }
  265. }
  266. }
  267. }
  268. //添加数据到数据库
  269. for _, v := range items {
  270. if codeMap[v.IndexName] == "" {
  271. codeMap[v.IndexName] = v.IndexCode
  272. newId, err := models.AddBaseFromCoalmineMapping(v)
  273. if err != nil {
  274. fmt.Println("添加指标名称错误")
  275. } else {
  276. fmt.Println("添加指标名称成功", newId)
  277. }
  278. }
  279. }
  280. fmt.Println("指标操作完成")
  281. for _, v := range itemsIndex {
  282. v.IndexCode = codeMap[v.IndexName]
  283. if indexMap[v.IndexName+v.DataTime] == "" && v.DealValue != "" {
  284. newId, err := models.AddBaseFromCoalmineIndex(v)
  285. if err != nil {
  286. fmt.Println("添加数据错误", err)
  287. } else {
  288. fmt.Println("新增成功", newId)
  289. }
  290. } else {
  291. if indexMap[v.IndexName+v.DataTime] != v.DealValue && v.DealValue != "" {
  292. err = models.UpdateBaseFromCoalmineIndex(v)
  293. if err != nil {
  294. fmt.Println("修改数据错误错误", err)
  295. return
  296. }
  297. }
  298. }
  299. }
  300. fmt.Println("数据操作完成")
  301. for _, v := range itemsCompany {
  302. if codeCompanyMap[v.IndexName] == "" {
  303. codeCompanyMap[v.IndexName] = v.IndexCode
  304. newId, err := models.AddBaseFromCoalmineMapping(v)
  305. if err != nil {
  306. for i := 0; i<10; i++ {
  307. v.IndexCode = v.IndexCode + strconv.Itoa(i)
  308. codeCompanyMap[v.IndexName] = v.IndexCode
  309. newId, err := models.AddBaseFromCoalmineMapping(v)
  310. if err != nil {
  311. fmt.Println("再次添加公司指标名称错误", err)
  312. fmt.Println(v.IndexName, v.IndexCode)
  313. continue
  314. } else {
  315. fmt.Println("新增公司成功", newId)
  316. break
  317. }
  318. }
  319. } else {
  320. fmt.Println("新增公司成功", newId)
  321. }
  322. }
  323. }
  324. fmt.Println("公司指标操作完成")
  325. for _, v := range itemsCompanyIndex {
  326. v.IndexCode = codeCompanyMap[v.IndexName]
  327. if indexCompanyMap[v.IndexName+v.DataTime] == "" && v.DealValue != "" {
  328. newId, err := models.AddBaseFromCoalmineCompanyIndex(v)
  329. if err != nil {
  330. fmt.Println("添加公司数据错误", err)
  331. } else {
  332. fmt.Println("新增公司数据成功", newId)
  333. }
  334. } else {
  335. if indexCompanyMap[v.IndexName+v.DataTime] != v.DealValue && v.DealValue != "" {
  336. err = models.UpdateBaseFromCoalmineCompanyIndex(v)
  337. if err != nil {
  338. fmt.Println("修改数据错误错误", err)
  339. }
  340. }
  341. }
  342. }
  343. return
  344. }
  345. func TrimCompanyName(name string) string {
  346. name = strings.Replace(name, "有限", "", -1)
  347. name = strings.Replace(name, "股份", "", -1)
  348. name = strings.Replace(name, "责任", "", -1)
  349. name = strings.Replace(name, "公司", "", -1)
  350. name = strings.Replace(name, "(", "", -1)
  351. name = strings.Replace(name, ")", "", -1)
  352. return name
  353. }
  354. func ContainsSpecialName(name string) bool {
  355. return strings.Contains(name, "陕西") ||
  356. strings.Contains(name, "海南") ||
  357. strings.Contains(name, "河南") ||
  358. strings.Contains(name, "河北") ||
  359. strings.Contains(name, "澳门") ||
  360. strings.Contains(name, "内蒙古") ||
  361. strings.Contains(name, "黑龙江")
  362. }
  363. func TrimProvinceName(name string) string {
  364. name = strings.Replace(name, "陕西省", "sns", -1)
  365. name = strings.Replace(name, "陕西", "sn", -1)
  366. name = strings.Replace(name, "海南市", "hi", -1)
  367. name = strings.Replace(name, "海南", "hi", -1)
  368. name = strings.Replace(name, "河南省", "has", -1)
  369. name = strings.Replace(name, "河南", "ha", -1)
  370. name = strings.Replace(name, "河北省", "hes", -1)
  371. name = strings.Replace(name, "河北", "he", -1)
  372. name = strings.Replace(name, "澳门", "mo", -1)
  373. name = strings.Replace(name, "内蒙古自治区", "nm", -1)
  374. name = strings.Replace(name, "内蒙古", "nm", -1)
  375. name = strings.Replace(name, "黑龙江", "hl", -1)
  376. name = strings.Replace(name, "(", "", -1)
  377. name = strings.Replace(name, ")", "", -1)
  378. name = strings.Replace(name, "+", "", -1)
  379. return name
  380. }