ChoiceBondServiceImpl.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. package com.zx.dataservice.service.impl;
  2. import com.alibaba.fastjson.JSON;
  3. import com.zx.dataservice.mapper2.ChoiceBondMapper;
  4. import com.zx.dataservice.pojo.StockRestPojo;
  5. import com.zx.dataservice.service.ChoiceBondService;
  6. import com.zx.dataservice.utils.FileBondUtil;
  7. import com.zx.dataservice.utils.HttpRequest;
  8. import com.zx.dataservice.utils.TimeUtil;
  9. import com.zx.dataservice.vo.StockRestVO;
  10. import org.apache.commons.lang3.StringUtils;
  11. import org.slf4j.Logger;
  12. import org.slf4j.LoggerFactory;
  13. import org.springframework.beans.BeanUtils;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.stereotype.Service;
  16. import java.io.File;
  17. import java.util.*;
  18. @Service
  19. public class ChoiceBondServiceImpl implements ChoiceBondService {
  20. private static final Logger log = LoggerFactory.getLogger(ChoiceBondServiceImpl.class);
  21. private static final String sourceFileUrl = "/www/wwwroot/csqdata/bond";
  22. private static final String goalFileUrl = "/www/wwwroot/csqdata/bond/backup";
  23. private static final String url = "http://taifooksec.com/api/stock/updateBatchStockInfo.do";
  24. @Autowired
  25. private ChoiceBondMapper choiceBondMapper;
  26. @Override
  27. public void analysisBondRestData() {
  28. // 1.获取文件夹文件 按照时间顺序拿到一个
  29. List<File> files = FileBondUtil.getFile(sourceFileUrl);
  30. if (null == files || 0 == files.size()) {
  31. return;
  32. }
  33. List<StockRestPojo> stockRestPojoList = new ArrayList<>();
  34. List<StockRestVO> stockRestVOList = new ArrayList<>();
  35. StockRestPojo stockRestPojo;
  36. StockRestVO stockRestVO;
  37. for (File file : files) {
  38. // 2.移动文件去另外一个文件夹
  39. FileBondUtil.moveFile(sourceFileUrl + File.separator + file.getName(), goalFileUrl);
  40. // 3.读取文件内容
  41. String str = FileBondUtil.readFileContent(goalFileUrl + File.separator + file.getName());
  42. // 4.并解析
  43. if(StringUtils.isEmpty(str)){
  44. continue;
  45. }
  46. Map<String, List<String>> map = new HashMap<String, List<String>>();
  47. map = JSON.parseObject(str, HashMap.class);
  48. str = null;
  49. for (Map.Entry<String, List<String>> entry : map.entrySet()) {
  50. try {
  51. stockRestPojo = new StockRestPojo();
  52. stockRestPojo.setDate(String.valueOf(entry.getValue().get(0)));
  53. if(String.valueOf(entry.getValue().get(1)).equals("0")){
  54. continue;
  55. }
  56. stockRestPojo.setTime(String.valueOf(entry.getValue().get(1)));
  57. stockRestPojo.setNow(String.valueOf(entry.getValue().get(2)));
  58. stockRestPojo.setHigh(String.valueOf(entry.getValue().get(3)));
  59. stockRestPojo.setLow(String.valueOf(entry.getValue().get(4)));
  60. stockRestPojo.setOpen(String.valueOf(entry.getValue().get(5)));
  61. stockRestPojo.setPreclose(String.valueOf(entry.getValue().get(6)));
  62. stockRestPojo.setRoundlot(String.valueOf(entry.getValue().get(7)));
  63. stockRestPojo.setChange(String.valueOf(entry.getValue().get(8)));
  64. stockRestPojo.setPctchange(String.valueOf(entry.getValue().get(9)));
  65. stockRestPojo.setVolume(String.valueOf(entry.getValue().get(10)));
  66. stockRestPojo.setAmount(String.valueOf(entry.getValue().get(11)));
  67. stockRestPojo.setVolumeratio("");
  68. stockRestPojo.setCommissionratio("");
  69. stockRestPojo.setCommissiondiff("");
  70. stockRestPojo.setTradestatus("");
  71. stockRestPojo.setOutvolume("");
  72. stockRestPojo.setInvolume("");
  73. stockRestPojo.setHighlimit("");
  74. stockRestPojo.setLowlimit("");
  75. stockRestPojo.setSpeed("");
  76. stockRestPojo.setAverageprice("");
  77. stockRestPojo.setBuyprice1(String.valueOf(entry.getValue().get(12)));
  78. stockRestPojo.setBuyprice2(String.valueOf(entry.getValue().get(13)));
  79. stockRestPojo.setBuyprice3(String.valueOf(entry.getValue().get(14)));
  80. stockRestPojo.setBuyprice4(String.valueOf(entry.getValue().get(15)));
  81. stockRestPojo.setBuyprice5(String.valueOf(entry.getValue().get(16)));
  82. stockRestPojo.setBuyvolume1(String.valueOf(entry.getValue().get(17)));
  83. stockRestPojo.setBuyvolume2(String.valueOf(entry.getValue().get(18)));
  84. stockRestPojo.setBuyvolume3(String.valueOf(entry.getValue().get(19)));
  85. stockRestPojo.setBuyvolume4(String.valueOf(entry.getValue().get(20)));
  86. stockRestPojo.setBuyvolume5(String.valueOf(entry.getValue().get(21)));
  87. stockRestPojo.setSellprice1(String.valueOf(entry.getValue().get(22)));
  88. stockRestPojo.setSellprice2(String.valueOf(entry.getValue().get(23)));
  89. stockRestPojo.setSellprice3(String.valueOf(entry.getValue().get(24)));
  90. stockRestPojo.setSellprice4(String.valueOf(entry.getValue().get(25)));
  91. stockRestPojo.setSellprice5(String.valueOf(entry.getValue().get(26)));
  92. stockRestPojo.setSellvolume1(String.valueOf(entry.getValue().get(27)));
  93. stockRestPojo.setSellvolume2(String.valueOf(entry.getValue().get(28)));
  94. stockRestPojo.setSellvolume3(String.valueOf(entry.getValue().get(29)));
  95. stockRestPojo.setSellvolume4(String.valueOf(entry.getValue().get(30)));
  96. stockRestPojo.setSellvolume5(String.valueOf(entry.getValue().get(31)));
  97. stockRestPojo.setClosedtime("");
  98. stockRestPojo.setClosedvolume("");
  99. stockRestPojo.setClosedamount("");
  100. StringBuffer dateStr = new StringBuffer(stockRestPojo.getDate());
  101. if (StringUtils.isEmpty(stockRestPojo.getTime())) {
  102. dateStr = dateStr.append(000000);
  103. } else {
  104. if (5 == stockRestPojo.getTime().length()) {
  105. // 长度为5表示 小时前面需要补0
  106. dateStr = dateStr.append(0).append(stockRestPojo.getTime());
  107. } else {
  108. dateStr = dateStr.append(stockRestPojo.getTime());
  109. }
  110. }
  111. Date date = TimeUtil.strToDate(dateStr.toString());
  112. // 毫秒转成秒
  113. stockRestPojo.setRealTime(date.getTime() / 1000);
  114. Calendar calendar = Calendar.getInstance();
  115. calendar.setTime(date);
  116. int min = calendar.get(Calendar.MINUTE); // 获取分钟
  117. int sec = calendar.get(Calendar.SECOND); // 获取秒数
  118. // 1分钟数据
  119. if (sec != 0) {
  120. stockRestPojo.setDateOne(stockRestPojo.getRealTime() + 60 - sec);
  121. } else {
  122. stockRestPojo.setDateOne(stockRestPojo.getRealTime());
  123. }
  124. // 5分钟数据
  125. if (sec != 0 || min % 5 != 0) {
  126. stockRestPojo.setDateFive(stockRestPojo.getRealTime() + (5 * 60) - sec - (min % 5 * 60));
  127. } else {
  128. stockRestPojo.setDateFive(stockRestPojo.getRealTime());
  129. }
  130. // 15分钟数据
  131. if (sec != 0 || min % 15 != 0) {
  132. stockRestPojo.setDateFifteen(stockRestPojo.getRealTime() + (15 * 60) - sec - (min % 15 * 60));
  133. } else {
  134. stockRestPojo.setDateFifteen(stockRestPojo.getRealTime());
  135. }
  136. // 30分钟数据
  137. if (sec != 0 || min % 30 != 0) {
  138. stockRestPojo.setDateThirty(stockRestPojo.getRealTime() + (30 * 60) - sec - (min % 30 * 60));
  139. } else {
  140. stockRestPojo.setDateThirty(stockRestPojo.getRealTime());
  141. }
  142. // 60分钟数据
  143. if (sec != 0 || min % 60 != 0) {
  144. stockRestPojo.setDateSixty(stockRestPojo.getRealTime() + (60 * 60) - sec - (min % 60 * 60));
  145. } else {
  146. stockRestPojo.setDateSixty(stockRestPojo.getRealTime());
  147. }
  148. StringBuffer tableName = new StringBuffer("data_rt_");
  149. tableName.append(entry.getKey().replace(".", "_").toLowerCase());
  150. stockRestPojo.setCode(entry.getKey().toLowerCase());
  151. stockRestPojo.setTableName(tableName.toString());
  152. stockRestPojoList.add(stockRestPojo);
  153. stockRestVO = new StockRestVO();
  154. BeanUtils.copyProperties(stockRestPojo, stockRestVO);
  155. stockRestVOList.add(stockRestVO);
  156. }catch (Exception e){
  157. log.error("错误数据导致失败" + e);
  158. }
  159. }
  160. map = null;
  161. }
  162. // 5.入库
  163. insertList(stockRestPojoList, stockRestVOList);
  164. stockRestPojoList = null;
  165. }
  166. private void insertList(List<StockRestPojo> list, List<StockRestVO> stockRestVOList) {
  167. int insertLength = list.size();
  168. int i = 0;
  169. int insertSize = 500;
  170. while (insertLength > insertSize) {
  171. choiceBondMapper.insertBatch(list.subList(i, i + insertSize));
  172. List<StockRestVO> subList = stockRestVOList.subList(i, i + insertSize);
  173. i = i + insertSize;
  174. insertLength = insertLength - insertSize;
  175. Thread thread=new Thread(new Runnable() {
  176. @Override
  177. public void run() {
  178. HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
  179. }
  180. });
  181. thread.start();
  182. }
  183. if (insertLength > 0) {
  184. choiceBondMapper.insertBatch(list.subList(i, i + insertLength));
  185. List<StockRestVO> subList = stockRestVOList.subList(i, i + insertLength);
  186. Thread thread=new Thread(new Runnable() {
  187. @Override
  188. public void run() {
  189. HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
  190. }
  191. });
  192. thread.start();
  193. }
  194. }
  195. }