data_source_longzhong.go 27 KB

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