data_source_longzhong.go 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950
  1. package services
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. "github.com/tealeg/xlsx"
  7. "hongze/hongze_task/models"
  8. "hongze/hongze_task/utils"
  9. "net/url"
  10. "os"
  11. "path/filepath"
  12. "rdluck_tools/http"
  13. "strconv"
  14. "time"
  15. )
  16. //获取隆众信息表中指标
  17. func GetLongZhongTargetInfoByExcel() {
  18. var err error
  19. defer func() {
  20. if err != nil {
  21. fmt.Println("err:" + err.Error())
  22. go utils.SendEmail("获取隆众指标信息失败"+time.Now().Format("2006-01-02 15:04:05"), ";Err:"+err.Error(), utils.EmailSendToUsers)
  23. return
  24. }
  25. }()
  26. excelPath := `./static/longzhong_0824.xlsx`
  27. file, err := xlsx.OpenFile(excelPath)
  28. if err != nil {
  29. fmt.Println("err:", err.Error())
  30. return
  31. }
  32. sheets := file.Sheets
  33. for k, v := range sheets {
  34. fmt.Println(k, v.Name)
  35. classify, err := models.GetEdbdataClassifyByClassifyName(v.Name)
  36. if err != nil {
  37. if err.Error() == utils.ErrNoRow() {
  38. err = errors.New("分类不存在:Err:" + err.Error())
  39. } else {
  40. err = err
  41. }
  42. return
  43. }
  44. if classify == nil {
  45. err = errors.New("分类不存在,请重新核对")
  46. return
  47. }
  48. classifyId := classify.ClassifyId
  49. classifyName := classify.ClassifyName
  50. fmt.Println(classifyId, classifyName)
  51. maxRow := v.MaxRow
  52. //maxCol := v.MaxCol
  53. fmt.Println(classifyName, maxRow)
  54. for i := 0; i < maxRow; i++ {
  55. row, err := v.Row(i)
  56. if err != nil {
  57. return
  58. }
  59. longzhongClassify := ""
  60. if i > 0 {
  61. longzhongClassifyNew := row.GetCell(0).String()
  62. if longzhongClassifyNew != "" {
  63. longzhongClassify = longzhongClassifyNew
  64. }
  65. secName := row.GetCell(1).Value
  66. frequency := row.GetCell(2).Value
  67. LongzhongId := row.GetCell(3).Value
  68. remark := row.GetCell(4).String()
  69. item := new(models.DataSourceLongzhong)
  70. item.ClassifyId = classifyId
  71. item.ClassifyName = classifyName
  72. item.SecName = secName
  73. item.Frequency = frequency
  74. item.LongzhongId = LongzhongId
  75. item.Remark = remark
  76. item.LongzhongClassify = longzhongClassify
  77. _, err = models.AddDataSourceLongzhong(item)
  78. if err != nil {
  79. fmt.Println("Err:", err.Error())
  80. return
  81. }
  82. }
  83. }
  84. }
  85. }
  86. func GetLzProductList() (err error) {
  87. utils.FileLog.Info("start GetLzProductList")
  88. defer func() {
  89. if err != nil {
  90. fmt.Println("Err:" + err.Error())
  91. go utils.SendEmail("获取隆众指标数据失败"+time.Now().Format("2006-01-02 15:04:05"), ";Err:"+err.Error(), utils.EmailSendToUsers)
  92. }
  93. }()
  94. postUrl := `http://info.oilchem.net/cust/interfacenew/getProductUnitListNew`
  95. username := "hzmd"
  96. password := "HZMD2020"
  97. timestamp := fmt.Sprintf("%d", time.Now().Unix())
  98. fmt.Println(timestamp)
  99. token := utils.MD5(username + timestamp + utils.MD5(password))
  100. fmt.Println("token:", token)
  101. param := url.Values{}
  102. param.Add("username", username)
  103. param.Add("password", password)
  104. param.Add("timestamp", timestamp)
  105. param.Add("token", token)
  106. utils.FileLog.Info("%s", param.Encode())
  107. body, err := http.Post(postUrl, param.Encode())
  108. if err != nil {
  109. fmt.Println("err:", err.Error())
  110. return
  111. }
  112. result := string(body)
  113. if result == "" {
  114. err = errors.New("返回内容为空")
  115. return
  116. }
  117. resp := new(models.LzProductInfoResp)
  118. err = json.Unmarshal(body, &resp)
  119. if err != nil {
  120. fmt.Println("json.Unmarshal Err:" + err.Error())
  121. return
  122. }
  123. if resp.Code != "1" {
  124. fmt.Println("获取信息失败")
  125. err = errors.New("Code:" + resp.Code + ";Msg:" + resp.Msg)
  126. return
  127. }
  128. fmt.Println("len")
  129. fmt.Println(len(resp.Data))
  130. for _, v := range resp.Data {
  131. fmt.Println(v.Unitid, v.ProName, v.ProUnitName)
  132. var classifyId int
  133. var classifyName string
  134. classify, err := models.GetEdbdataClassifyByClassifyName(v.ProName)
  135. if err != nil && err.Error() != utils.ErrNoRow() {
  136. fmt.Println("获取分类失败,Err:" + err.Error())
  137. return err
  138. }
  139. if classify == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  140. classifyItem := new(models.EdbdataClassify)
  141. classifyItem.ClassifyName = v.ProName
  142. classifyItem.ParentId = 4
  143. classifyItem.CreateTime = time.Now()
  144. newId, err := models.AddEdbdataClassify(classifyItem)
  145. if err != nil {
  146. fmt.Println("新增分类失败,Err:" + err.Error())
  147. return err
  148. }
  149. classifyId = int(newId)
  150. classifyName = v.ProName
  151. } else {
  152. classifyId = classify.ClassifyId
  153. classifyName = classify.ClassifyName
  154. }
  155. count, err := models.GetLongzhonginfoCount(classifyId, v.Unitid)
  156. if err != nil {
  157. fmt.Println("判断指标是否存在失败,Err:" + err.Error())
  158. return err
  159. }
  160. if count > 0 { //修改
  161. lzProduct := new(models.Longzhonginfo)
  162. lzProduct.SecName = v.ProUnitName
  163. lzProduct.Frequency = v.LzType
  164. lzProduct.ClassifyId = classifyId
  165. lzProduct.ClassifyName = classifyName
  166. lzProduct.Unit = v.Unit
  167. lzProduct.CreateTime = time.Now()
  168. if v.IsNormal == "" {
  169. v.IsNormal = "1"
  170. }
  171. lzProduct.IsNormal = v.IsNormal
  172. lzProduct.LastModifyDate = v.Maxdate
  173. lzProduct.Unitid = v.Unitid
  174. lzProduct.TempId = v.Tempid
  175. lzProduct.TempName = v.TempName
  176. lzProduct.ModifyTime = time.Now()
  177. err = models.ModifyLongzhonginfo(lzProduct)
  178. if err != nil {
  179. fmt.Println("修改失败,Err:" + err.Error())
  180. return err
  181. }
  182. } else { //新增
  183. maxId, err := models.GetLongzhonginfoMaxId()
  184. if err != nil {
  185. fmt.Println("获取编码失败,err:" + err.Error())
  186. return err
  187. }
  188. tradeCode := fmt.Sprintf("L%06d", maxId+1)
  189. lzProduct := new(models.Longzhonginfo)
  190. lzProduct.TradeCode = tradeCode
  191. lzProduct.SecName = v.ProUnitName
  192. lzProduct.Frequency = v.LzType
  193. lzProduct.ClassifyId = classifyId
  194. lzProduct.ClassifyName = classifyName
  195. lzProduct.Unit = v.Unit
  196. lzProduct.CreateTime = time.Now()
  197. if v.IsNormal == "" {
  198. v.IsNormal = "1"
  199. }
  200. lzProduct.IsNormal = v.IsNormal
  201. lzProduct.LastModifyDate = v.Maxdate
  202. lzProduct.Unitid = v.Unitid
  203. lzProduct.TempId = v.Tempid
  204. lzProduct.TempName = v.TempName
  205. lzProduct.ModifyTime = time.Now()
  206. _, err = models.AddLongzhonginfo(lzProduct)
  207. if err != nil {
  208. fmt.Println("新增指标信息失败")
  209. return err
  210. }
  211. }
  212. }
  213. return
  214. }
  215. func GetLzProductDetail() (err error) {
  216. utils.FileLog.Info("start GetLzProductDetail")
  217. defer func() {
  218. if err != nil {
  219. fmt.Println("Err:" + err.Error())
  220. }
  221. }()
  222. startDate := "2017-01-01"//time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
  223. endDate := "2017-12-31"//time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
  224. time.Sleep(5 * time.Second)
  225. pageSize := 30
  226. postUrl := `http://info.oilchem.net/cust/interfacenew/getProductUnitDetailNew`
  227. username := "hzmd"
  228. password := "HZMD2020"
  229. totalPage := 10
  230. for i := 1; i <= totalPage; i++ {
  231. fmt.Println("page:", i)
  232. timestamp := fmt.Sprintf("%d", time.Now().Unix())
  233. token := utils.MD5(username + timestamp + utils.MD5(password))
  234. param := url.Values{}
  235. param.Add("username", username)
  236. param.Add("password", password)
  237. param.Add("timestamp", timestamp)
  238. param.Add("token", token)
  239. //param.Add("id", "334")
  240. param.Add("startDate", startDate)
  241. param.Add("endDate", endDate)
  242. param.Add("pagesize", strconv.Itoa(pageSize))
  243. param.Add("page", strconv.Itoa(i))
  244. utils.FileLog.Info("%s", param.Encode())
  245. body, err := http.Post(postUrl, param.Encode())
  246. if err != nil {
  247. fmt.Println("err:", err.Error())
  248. return err
  249. }
  250. fmt.Println(string(body))
  251. utils.FileLog.Info("%s", string(body))
  252. resp := new(models.LzProductInfoDetailResp)
  253. err = json.Unmarshal(body, &resp)
  254. if err != nil {
  255. fmt.Println("Unmarshal Err:" + err.Error())
  256. return err
  257. }
  258. if resp.Code != "1" {
  259. fmt.Println("获取信息失败")
  260. err = errors.New("Code:" + resp.Code + ";Msg:" + resp.Msg)
  261. return err
  262. }
  263. if i == totalPage && resp.Pagesize >= pageSize {
  264. totalPage = totalPage + 5
  265. }
  266. for k, v := range resp.Data {
  267. fmt.Println(k, v.UnitId, v.ProCnName)
  268. target, err := models.GetLongzhonginfoByUnitId(v.ProCnName, v.UnitId)
  269. if err != nil {
  270. if err.Error() != utils.ErrNoRow() {
  271. fmt.Println("获取target失败,err:" + err.Error())
  272. continue
  273. }
  274. fmt.Println("err:" + err.Error())
  275. return err
  276. }
  277. if target == nil {
  278. fmt.Println("target is empty:"+v.ProCnName, v.UnitId)
  279. continue
  280. }
  281. count, err := models.GetLongzhongdataCount(target.LongzhonginfoId, v.DataTime)
  282. if err != nil {
  283. fmt.Println("GetLongzhongdataCount Err:" + err.Error())
  284. return err
  285. }
  286. if count > 0 {
  287. lzdetail := new(models.Longzhongdata)
  288. lzdetail.CreateTime = time.Now()
  289. lzdetail.ModifyTime = time.Now()
  290. lzdetail.TradeCode = target.TradeCode
  291. lzdetail.LongzhonginfoId = target.LongzhonginfoId
  292. lzdetail.Dt = v.DataTime
  293. lzdetail.Close = v.UnitValue
  294. lzdetail.UnitDesc = v.UnitDesc
  295. lzdetail.UpdTime = v.UpdTime
  296. err = models.ModifyLongzhongdata(lzdetail)
  297. if err != nil {
  298. fmt.Println("ModifyLongzhongdata Err:" + err.Error())
  299. return err
  300. }
  301. } else {
  302. lzdetail := new(models.Longzhongdata)
  303. lzdetail.CreateTime = time.Now()
  304. lzdetail.ModifyTime = time.Now()
  305. lzdetail.TradeCode = target.TradeCode
  306. lzdetail.LongzhonginfoId = target.LongzhonginfoId
  307. lzdetail.Dt = v.DataTime
  308. lzdetail.Close = v.UnitValue
  309. lzdetail.UnitDesc = v.UnitDesc
  310. lzdetail.UpdTime = v.UpdTime
  311. err = models.AddLongzhongdata(lzdetail)
  312. if err != nil {
  313. fmt.Println("AddLongzhongdata Err:" + err.Error())
  314. return err
  315. }
  316. }
  317. }
  318. if resp.Pagesize < pageSize || len(resp.Data) == 0 {
  319. return err
  320. }
  321. time.Sleep(2 * time.Second)
  322. }
  323. return
  324. }
  325. //获取历史隆众数据
  326. func GetHistoryLzProductDetail() (err error) {
  327. utils.FileLog.Info("start GetHistoryLzProductDetail")
  328. var msg string
  329. defer func() {
  330. if err != nil {
  331. fmt.Println("Err:" + err.Error())
  332. }
  333. if msg != "" {
  334. fmt.Println("msg:" + msg)
  335. }
  336. }()
  337. infoList, err := models.GetLongzhonginfoList()
  338. if err != nil {
  339. msg = "获取指标列表失败,Err:" + err.Error()
  340. return
  341. }
  342. for ik, iv := range infoList {
  343. fmt.Println(ik, iv.SecName)
  344. startDate := "2020-01-01" //time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
  345. endDate := "2020-12-31" //time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
  346. //time.Sleep(1 * time.Second)
  347. pageSize := 30
  348. postUrl := `http://info.oilchem.net/cust/interfacenew/getProductUnitDetailNew`
  349. username := "hzmd"
  350. password := "HZMD2020"
  351. totalPage := 10
  352. for i := 1; i <= totalPage; i++ {
  353. fmt.Println("page:", i)
  354. timestamp := fmt.Sprintf("%d", time.Now().Unix())
  355. token := utils.MD5(username + timestamp + utils.MD5(password))
  356. param := url.Values{}
  357. param.Add("username", username)
  358. param.Add("password", password)
  359. param.Add("timestamp", timestamp)
  360. param.Add("token", token)
  361. param.Add("id", strconv.Itoa(iv.Unitid))
  362. param.Add("startDate", startDate)
  363. param.Add("endDate", endDate)
  364. if i > 1 {
  365. param.Add("page", strconv.Itoa(i))
  366. }
  367. param.Add("pagesize", strconv.Itoa(pageSize))
  368. utils.FileLog.Info("%s", param.Encode())
  369. fmt.Println("post url:", postUrl)
  370. fmt.Println("post params:", param.Encode())
  371. body, err := http.Post(postUrl, param.Encode())
  372. if err != nil {
  373. fmt.Println("err:", err.Error())
  374. return err
  375. }
  376. utils.FileLog.Info("%s", string(body))
  377. fmt.Println("body:", string(body))
  378. resp := new(models.LzProductInfoDetailResp)
  379. err = json.Unmarshal(body, &resp)
  380. if err != nil {
  381. fmt.Println("Unmarshal Err:" + err.Error())
  382. fmt.Println("body:", string(body))
  383. return err
  384. }
  385. if resp.Code != "1" {
  386. fmt.Println("获取信息失败")
  387. err = errors.New("Code:" + resp.Code + ";Msg:" + resp.Msg)
  388. return err
  389. }
  390. if i == totalPage && resp.Pagesize >= pageSize {
  391. totalPage = totalPage + 5
  392. }
  393. for k, v := range resp.Data {
  394. fmt.Println(k, v.UnitId, v.ProCnName)
  395. target, err := models.GetLongzhonginfoByUnitId(v.ProCnName, v.UnitId)
  396. if err != nil {
  397. if err.Error() != utils.ErrNoRow() {
  398. fmt.Println("获取target失败,err:" + err.Error())
  399. continue
  400. }
  401. fmt.Println("err:" + err.Error())
  402. return err
  403. }
  404. if target == nil {
  405. fmt.Println("target is empty:"+v.ProCnName, v.UnitId)
  406. continue
  407. }
  408. count, err := models.GetLongzhongdataCount(target.LongzhonginfoId, v.DataTime)
  409. if err != nil {
  410. fmt.Println("GetLongzhongdataCount Err:" + err.Error())
  411. return err
  412. }
  413. if count > 0 {
  414. fmt.Println("数据已存在:", iv.Unitid, iv.SecName, v.UnitValue, v.DataTime)
  415. /*lzdetail := new(models.Longzhongdata)
  416. lzdetail.CreateTime = time.Now()
  417. lzdetail.ModifyTime = time.Now()
  418. lzdetail.TradeCode = target.TradeCode
  419. lzdetail.LongzhonginfoId = target.LongzhonginfoId
  420. lzdetail.Dt = v.DataTime
  421. lzdetail.Close = v.UnitValue
  422. lzdetail.UnitDesc = v.UnitDesc
  423. lzdetail.UpdTime = v.UpdTime
  424. err = models.ModifyLongzhongdata(lzdetail)
  425. if err != nil {
  426. fmt.Println("ModifyLongzhongdata Err:" + err.Error())
  427. return err
  428. }*/
  429. } else {
  430. lzdetail := new(models.Longzhongdata)
  431. lzdetail.CreateTime = time.Now()
  432. lzdetail.ModifyTime = time.Now()
  433. lzdetail.TradeCode = target.TradeCode
  434. lzdetail.LongzhonginfoId = target.LongzhonginfoId
  435. lzdetail.Dt = v.DataTime
  436. lzdetail.Close = v.UnitValue
  437. lzdetail.UnitDesc = v.UnitDesc
  438. lzdetail.UpdTime = v.UpdTime
  439. err = models.AddLongzhongdata(lzdetail)
  440. if err != nil {
  441. fmt.Println("AddLongzhongdata Err:" + err.Error())
  442. return err
  443. }
  444. }
  445. }
  446. if i == 1 && len(resp.Data) == 0 {
  447. utils.FileLog.Info("%d", iv.Unitid)
  448. }
  449. if resp.Pagesize < pageSize || len(resp.Data) == 0 {
  450. break
  451. }
  452. //time.Sleep(1 * time.Second)
  453. }
  454. err = models.ModifyLongzhonginfoIsNormal(iv.LongzhonginfoId)
  455. if err != nil {
  456. fmt.Println("ModifyLongzhonginfoIsNormal:Err" + err.Error())
  457. }
  458. fmt.Println("sleep", iv.SecName)
  459. time.Sleep(1 * time.Second)
  460. }
  461. return
  462. }
  463. func GetLzPrice() {
  464. fmt.Println("start")
  465. /*getUrl:=`https://openapi.oilchem.net/price/getProduct?password=HZMD2020&type=guoji&username=hzmd`
  466. result,err:=http.Get(getUrl)
  467. fmt.Println(string(result),err)
  468. utils.FileLog.Info("%s",string(result))*/
  469. getUrl := `https://openapi.oilchem.net/price/getPrice?password=HZMD2020&type=guoji&username=hzmd&inStartDate=2020-08-20&inEndDate=2020-08-26`
  470. result, err := http.Get(getUrl)
  471. fmt.Println(string(result), err)
  472. utils.FileLog.Info("%s", string(result))
  473. fmt.Println("end")
  474. }
  475. func LzExportExcel() {
  476. var err error
  477. defer func() {
  478. if err != nil {
  479. fmt.Println("err:" + err.Error())
  480. }
  481. }()
  482. parentId := 4
  483. classifyList, err := models.GetEdbdataClassifyByParentId(parentId)
  484. if err != nil {
  485. return
  486. }
  487. xlsxFile := xlsx.NewFile()
  488. if err != nil {
  489. fmt.Println("生成文件失败" + err.Error())
  490. return
  491. }
  492. dir, _ := os.Executable()
  493. exPath := filepath.Dir(dir)
  494. downLoadnFilePath := exPath + "/static/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  495. fmt.Println("downLoadnFilePath")
  496. fmt.Println(downLoadnFilePath)
  497. for _, v := range classifyList {
  498. fmt.Println(v.ClassifyId, v.ClassifyName)
  499. //获取指标
  500. secNameList, err := models.GetLongzhonginfoByClassifyId(v.ClassifyId)
  501. if err != nil {
  502. fmt.Println("获取数据失败,Err:" + err.Error())
  503. return
  504. }
  505. if len(secNameList) <= 0 {
  506. continue
  507. }
  508. sheetNew, err := xlsxFile.AddSheet(v.ClassifyName)
  509. if err != nil {
  510. fmt.Println("新增Sheet失败", err.Error())
  511. return
  512. }
  513. //获取指标数据
  514. windRow := sheetNew.AddRow()
  515. secNameRow := sheetNew.AddRow()
  516. frequencyRow := sheetNew.AddRow()
  517. unitRow := sheetNew.AddRow()
  518. lastModifyDateRow := sheetNew.AddRow()
  519. //获取分类下指标最大数据量
  520. dataMax, err := models.GetLongzhongDataMaxCount(v.ClassifyId)
  521. if err != nil {
  522. fmt.Println("获取指标最大数据量失败", err.Error())
  523. return
  524. }
  525. for _, sv := range secNameList {
  526. fmt.Println("line 399:", v.ClassifyId, v.ClassifyName, sv.SecName, sv.Frequency)
  527. windRow.AddCell().SetValue("Wind")
  528. secNameRow.AddCell().SetValue("指标名称")
  529. frequencyRow.AddCell().SetValue("频率")
  530. unitRow.AddCell().SetValue("单位")
  531. lastModifyDateRow.AddCell().SetValue("更新时间")
  532. secNameRow.AddCell().SetValue(sv.SecName)
  533. frequencyRow.AddCell().SetValue(sv.Frequency)
  534. unitRow.AddCell().SetValue(sv.Unit)
  535. lastModifyDateRow.AddCell().SetValue(sv.LastModifyDate)
  536. windRow.AddCell()
  537. windRow.AddCell()
  538. secNameRow.AddCell()
  539. frequencyRow.AddCell()
  540. unitRow.AddCell()
  541. lastModifyDateRow.AddCell()
  542. //获取数据
  543. dataList, err := models.GetLongzhongDataById(sv.LongzhonginfoId)
  544. if err != nil {
  545. fmt.Println("GetLongzhongDataById Err:" + err.Error())
  546. return
  547. }
  548. if len(dataList) <= 0 {
  549. for n := 0; n < dataMax; n++ {
  550. rowIndex := 5 + n
  551. row, err := sheetNew.Row(rowIndex)
  552. if err != nil {
  553. fmt.Println("add row err:" + err.Error())
  554. return
  555. }
  556. row.AddCell()
  557. row.AddCell()
  558. row.AddCell()
  559. }
  560. } else {
  561. endRowIndex := 0
  562. for rk, dv := range dataList {
  563. rowIndex := 5 + rk
  564. row, err := sheetNew.Row(rowIndex)
  565. if err != nil {
  566. fmt.Println("add row err:" + err.Error())
  567. return
  568. }
  569. row.AddCell().SetValue(dv.Dt)
  570. row.AddCell().SetFloat(dv.Close)
  571. row.AddCell()
  572. endRowIndex = rowIndex
  573. }
  574. if len(dataList) < dataMax {
  575. dataLen := dataMax - len(dataList)
  576. for n := 0; n < dataLen; n++ {
  577. rowIndex := (endRowIndex + 1) + n
  578. row, err := sheetNew.Row(rowIndex)
  579. if err != nil {
  580. fmt.Println("add row err:" + err.Error())
  581. return
  582. }
  583. row.AddCell()
  584. row.AddCell()
  585. row.AddCell()
  586. }
  587. }
  588. }
  589. }
  590. }
  591. err = xlsxFile.Save(downLoadnFilePath)
  592. fmt.Print("downLoadnFilePath:", downLoadnFilePath)
  593. if err != nil {
  594. return
  595. }
  596. }
  597. func GetLzProductPriceProduct() (err error) {
  598. var msg string
  599. defer func() {
  600. if err != nil {
  601. fmt.Println("Err:" + err.Error())
  602. go utils.SendEmail("获取隆众价格指标失败"+time.Now().Format("2006-01-02 15:04:05"), ";Err:"+err.Error(), utils.EmailSendToUsers)
  603. }
  604. if msg != "" {
  605. fmt.Println("msg:", msg)
  606. go utils.SendEmail("获取隆众价格指标失败"+time.Now().Format("2006-01-02 15:04:05"), ";msg:"+msg, utils.EmailSendToUsers)
  607. }
  608. }()
  609. //chuchang, guonei, guoji, oil ,lingshou,guojioil,base,国内出厂,国内市场,国际市场,国内成品油批发价,国内成品油零售价,国际原油,基准价
  610. typeMap := make(map[string]string)
  611. typeMap["chuchang"] = "国内出厂"
  612. typeMap["guonei"] = "国内市场"
  613. typeMap["guoji"] = "国际市场"
  614. typeMap["oil"] = "国内成品油批发价"
  615. typeMap["lingshou"] = "国内成品油零售价"
  616. typeMap["guojioil"] = "国际原油"
  617. typeMap["base"] = "基准价"
  618. username := "hzmd"
  619. password := "HZMD2020"
  620. for k, v := range typeMap {
  621. fmt.Println(k, v)
  622. getUrl := `https://openapi.oilchem.net/price/getProduct?password=` + password + `&type=` + k + `&username=` + username + ``
  623. body, err := http.Get(getUrl)
  624. if err != nil {
  625. msg = "获取隆众价格指标失败:Err" + err.Error()
  626. return err
  627. }
  628. fmt.Println("getUrl:", getUrl)
  629. fmt.Println("body", string(body))
  630. utils.FileLog.Info("%s", string(body))
  631. infoList := new(models.LzPriceInfoResp)
  632. err = json.Unmarshal(body, &infoList)
  633. if err != nil {
  634. msg = "获取隆众价格指标失败:Unmarshal Err " + err.Error() + " ;body:" + string(body)
  635. return err
  636. }
  637. if infoList.Code != 1 {
  638. msg = "获取隆众价格指标失败:body " + string(body)
  639. return nil
  640. }
  641. for _, n := range infoList.Data {
  642. count, err := models.GetLongzhongpriceinfoCount(n.Id)
  643. if err != nil {
  644. msg = "判断隆众价格指标是否存在失败:err " + err.Error()
  645. return err
  646. }
  647. item := new(models.Longzhongpriceinfo)
  648. item.Standard = n.Standard
  649. item.ModelName = n.ModelName
  650. item.Unit = n.Unit
  651. item.AreaName = n.AreaName
  652. item.PriceType = n.PriceType
  653. item.Memo = n.Memo
  654. item.PriceId = n.Id
  655. item.ProductName = n.ProductName
  656. item.InfoType = k
  657. item.InfoTypeRemark = v
  658. item.MarketName = n.MarketName
  659. item.ManufactureName = n.ManufactureName
  660. if count > 0 {
  661. fmt.Println("存在", n.ProductName, n.Id)
  662. //修改
  663. err = models.ModifyLongzhongpriceinfo(item)
  664. if err != nil {
  665. msg = "修改隆众价格指标失败:err " + err.Error()
  666. return err
  667. }
  668. } else {
  669. _, err = models.AddLongzhongpriceinfo(item)
  670. if err != nil {
  671. msg = "新增隆众价格指标失败:err " + err.Error()
  672. return err
  673. }
  674. }
  675. }
  676. time.Sleep(31 * time.Second)
  677. }
  678. return
  679. }
  680. func GetLzProductPriceData() (err error) {
  681. var msg string
  682. defer func() {
  683. if err != nil {
  684. fmt.Println("Err:" + err.Error())
  685. go utils.SendEmail("获取隆众价格指标失败"+time.Now().Format("2006-01-02 15:04:05"), ";Err:"+err.Error(), utils.EmailSendToUsers)
  686. }
  687. if msg != "" {
  688. fmt.Println("msg:", msg)
  689. go utils.SendEmail("获取隆众价格指标失败"+time.Now().Format("2006-01-02 15:04:05"), ";msg:"+msg, utils.EmailSendToUsers)
  690. utils.FileLog.Info("%s", msg)
  691. }
  692. }()
  693. priceInfoList, err := models.GetLongzhongpriceinfo()
  694. if err != nil {
  695. msg = "获取价格指标失败,Err:" + err.Error()
  696. return
  697. }
  698. username := "hzmd"
  699. password := "HZMD2020"
  700. startDate := time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
  701. endDate := time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
  702. for k, v := range priceInfoList {
  703. fmt.Println(k, v)
  704. getUrl := `https://openapi.oilchem.net/price/getPrice?password=` + password + `&type=` + v.InfoType + `&username=` + username + `&inStartDate=` + startDate + `&inEndDate=` + endDate + `&id=` + v.PriceId
  705. body, err := http.Get(getUrl)
  706. if err != nil {
  707. msg = "获取隆众价格数据失败:Err" + err.Error()
  708. return err
  709. }
  710. fmt.Println("getUrl:", getUrl)
  711. fmt.Println("body", string(body))
  712. infoList := new(models.LzPriceDataResp)
  713. err = json.Unmarshal(body, &infoList)
  714. if err != nil {
  715. msg = "获取隆众价格数据失败:Unmarshal Err " + err.Error() + " ;body:" + string(body)
  716. return err
  717. }
  718. if infoList.Code != 1 {
  719. msg = "获取隆众价格数据失败:body " + string(body)
  720. return nil
  721. }
  722. for _, n := range infoList.Data {
  723. count, err := models.GetLongzhongpricedataCount(n.Id, n.PriceDate)
  724. if err != nil {
  725. msg = "获取隆众价格数据失败:err " + err.Error()
  726. return err
  727. }
  728. if count > 0 {
  729. fmt.Println("存在", n.PriceDate, n.Id)
  730. } else {
  731. item := new(models.Longzhongpricedata)
  732. item.LongzhongpriceinfoId = v.LongzhongpriceinfoId
  733. item.PriceDate = n.PriceDate
  734. item.Memo = n.Memo
  735. item.Price = n.Price
  736. item.CnyPrice = n.CnyPrice
  737. item.ZsyPrice = n.ZsyPrice
  738. item.ZshPrice = n.ZshPrice
  739. item.LowPrice = n.LowPrice
  740. item.HighPrice = n.HighPrice
  741. item.RisePrice = n.RisePrice
  742. item.TonPrice = n.TonPrice
  743. item.PriceType = n.PriceType
  744. item.UpdateDate = n.UpdateDate
  745. _, err = models.AddLongzhongpricedata(item)
  746. if err != nil {
  747. msg = "新增隆众价格数据失败:err " + err.Error()
  748. return err
  749. }
  750. }
  751. }
  752. }
  753. return
  754. }
  755. func LzPriceExportExcel() {
  756. var err error
  757. defer func() {
  758. if err != nil {
  759. fmt.Println("err:" + err.Error())
  760. }
  761. }()
  762. classifyList, err := models.GetLzPriceClassify()
  763. if err != nil {
  764. return
  765. }
  766. xlsxFile := xlsx.NewFile()
  767. if err != nil {
  768. fmt.Println("生成文件失败" + err.Error())
  769. return
  770. }
  771. dir, _ := os.Executable()
  772. exPath := filepath.Dir(dir)
  773. downLoadnFilePath := exPath + "/static/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  774. fmt.Println("downLoadnFilePath")
  775. fmt.Println(downLoadnFilePath)
  776. for _, v := range classifyList {
  777. fmt.Println(v.ProductName)
  778. //获取指标
  779. secNameList, err := models.GetLongzhongpriceinfoByClassifyName(v.ProductName)
  780. if err != nil {
  781. fmt.Println("获取数据失败,Err:" + err.Error())
  782. return
  783. }
  784. if len(secNameList) <= 0 {
  785. continue
  786. }
  787. sheetNew, err := xlsxFile.AddSheet(v.ProductName)
  788. if err != nil {
  789. fmt.Println("新增Sheet失败", err.Error())
  790. return
  791. }
  792. //获取指标数据
  793. windRow := sheetNew.AddRow()
  794. secNameRow := sheetNew.AddRow()
  795. frequencyRow := sheetNew.AddRow()
  796. unitRow := sheetNew.AddRow()
  797. lastModifyDateRow := sheetNew.AddRow()
  798. marketRow := sheetNew.AddRow()
  799. manufactureRow := sheetNew.AddRow()
  800. titleRow := sheetNew.AddRow()
  801. //获取分类下指标最大数据量
  802. dataMax, err := models.GetLongzhongPriceDataMaxCount(v.ProductName)
  803. if err != nil {
  804. fmt.Println("获取指标最大数据量失败", err.Error())
  805. return
  806. }
  807. for _, sv := range secNameList {
  808. fmt.Println("line 399:", v.ProductName, sv.InfoTypeRemark, sv.AreaName)
  809. windRow.AddCell().SetString("Wind")
  810. secNameRow.AddCell().SetValue("分类")
  811. frequencyRow.AddCell().SetValue("价格类型")
  812. unitRow.AddCell().SetValue("单位")
  813. lastModifyDateRow.AddCell().SetValue("地区")
  814. marketRow.AddCell().SetValue("市场名称")
  815. manufactureRow.AddCell().SetValue("厂家名称")
  816. secNameRow.AddCell().SetValue(sv.InfoTypeRemark)
  817. frequencyRow.AddCell().SetValue(sv.PriceType)
  818. unitRow.AddCell().SetValue(sv.Unit)
  819. lastModifyDateRow.AddCell().SetValue(sv.AreaName)
  820. marketRow.AddCell().SetValue(sv.MarketName)
  821. manufactureRow.AddCell().SetValue(sv.ManufactureName)
  822. windRow.AddCell()
  823. windRow.AddCell()
  824. windRow.AddCell()
  825. windRow.AddCell()
  826. secNameRow.AddCell()
  827. frequencyRow.AddCell()
  828. unitRow.AddCell()
  829. lastModifyDateRow.AddCell()
  830. marketRow.AddCell()
  831. manufactureRow.AddCell()
  832. secNameRow.AddCell()
  833. frequencyRow.AddCell()
  834. unitRow.AddCell()
  835. lastModifyDateRow.AddCell()
  836. marketRow.AddCell()
  837. manufactureRow.AddCell()
  838. secNameRow.AddCell()
  839. frequencyRow.AddCell()
  840. unitRow.AddCell()
  841. lastModifyDateRow.AddCell()
  842. marketRow.AddCell()
  843. manufactureRow.AddCell()
  844. titleRow.AddCell().SetValue("价格日期")
  845. titleRow.AddCell().SetValue("价格")
  846. titleRow.AddCell().SetValue("低端价格")
  847. titleRow.AddCell().SetValue("高端价格")
  848. titleRow.AddCell()
  849. //获取数据
  850. dataList, err := models.GetLongzhongPriceDataById(sv.LongzhongpriceinfoId)
  851. if err != nil {
  852. fmt.Println("GetLongzhongDataById Err:" + err.Error())
  853. return
  854. }
  855. if len(dataList) <= 0 {
  856. for n := 0; n < dataMax; n++ {
  857. rowIndex := 8 + n
  858. row, err := sheetNew.Row(rowIndex)
  859. if err != nil {
  860. fmt.Println("add row err:" + err.Error())
  861. return
  862. }
  863. row.AddCell()
  864. row.AddCell()
  865. row.AddCell()
  866. row.AddCell()
  867. row.AddCell()
  868. }
  869. } else {
  870. endRowIndex := 0
  871. for rk, dv := range dataList {
  872. rowIndex := 8 + rk
  873. row, err := sheetNew.Row(rowIndex)
  874. if err != nil {
  875. fmt.Println("add row err:" + err.Error())
  876. return
  877. }
  878. row.AddCell().SetValue(dv.PriceDate)
  879. row.AddCell().SetFloat(dv.Price)
  880. row.AddCell().SetFloat(dv.LowPrice)
  881. row.AddCell().SetFloat(dv.HighPrice)
  882. row.AddCell()
  883. endRowIndex = rowIndex
  884. }
  885. if len(dataList) < dataMax {
  886. dataLen := dataMax - len(dataList)
  887. for n := 0; n < dataLen; n++ {
  888. rowIndex := (endRowIndex + 1) + n
  889. row, err := sheetNew.Row(rowIndex)
  890. if err != nil {
  891. fmt.Println("add row err:" + err.Error())
  892. return
  893. }
  894. row.AddCell()
  895. row.AddCell()
  896. row.AddCell()
  897. row.AddCell()
  898. row.AddCell()
  899. }
  900. }
  901. }
  902. }
  903. }
  904. err = xlsxFile.Save(downLoadnFilePath)
  905. fmt.Print("downLoadnFilePath:", downLoadnFilePath)
  906. if err != nil {
  907. return
  908. }
  909. }