123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778 |
- package com.zx.dataservice.service.impl;
- import com.alibaba.fastjson.JSON;
- import com.zx.dataservice.controller.WebSocketController;
- import com.zx.dataservice.mapper1.ChoiceStockMapper;
- import com.zx.dataservice.pojo.StockRestPojo;
- import com.zx.dataservice.redismessage.util.RedisUtil;
- import com.zx.dataservice.service.ChoiceStockService;
- import com.zx.dataservice.utils.*;
- import com.zx.dataservice.vo.StockRestRedisVO;
- import com.zx.dataservice.vo.StockRestVO;
- import org.apache.commons.lang3.StringUtils;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.BeanUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import java.io.File;
- import java.math.BigDecimal;
- import java.util.*;
- import java.util.concurrent.TimeUnit;
- @Service
- public class ChoiceStockServiceImpl implements ChoiceStockService {
- private static final Logger log = LoggerFactory.getLogger(ChoiceStockServiceImpl.class);
- private static final String sourceFileUrl = "/www/wwwroot/csqdata/stock";
- private static final String goalFileUrl = "/www/wwwroot/csqdata/stock/backup";
- private static final String url = "http://qwer16888.vip/api/stock/updateBatchStockInfo.do";
- private static final String urlRedis = "http://qwer16888.vip/init/redis/updateInfo.do";
- private static final String sourceAfterFileUrl = "/www/wwwroot/csqdata/stock/after";
- private static final String goalAfterFileUrl = "/www/wwwroot/csqdata/stock/after/backup";
- private static final String sourceFileUrlInFront = "/www/wwwroot/csqdata/stock/InFront"; // 盘前
- private static final String goalFileUrlInFront = "/www/wwwroot/csqdata/stock/backup/InFront"; //盘前 备份
- @Autowired
- private RedisUtil redisUtil;
- @Autowired
- private ChoiceStockMapper choiceStockMapper;
- @Override
- public void analysisStockRestData(String type) {
- // 1.获取文件夹文件 按照时间顺序拿到一个
- List<File> files = FileStockUtil.getFile(sourceFileUrl);
- if(null == files || 0 == files.size()){
- return;
- }
- List<StockRestPojo> stockRestPojoList = new ArrayList<>();
- List<StockRestVO> stockRestVOList = new ArrayList<>();
- List<StockRestRedisVO> stockRestRedisVOList = new ArrayList<>();
- StockRestPojo stockRestPojo;
- StockRestVO stockRestVO;
- StockRestRedisVO stockRestRedisVO;
- for (File file : files){
- // 2.移动文件去另外一个文件夹
- FileStockUtil.moveFile(sourceFileUrl + File.separator + file.getName(), goalFileUrl);
- // 3.读取文件内容
- String str = FileStockUtil.readFileContent(goalFileUrl + File.separator + file.getName());
- // 4.并解析
- if(StringUtils.isEmpty(str)){
- continue;
- }
- Map<String, List<String>> map = new HashMap<String, List<String>>();
- map = JSON.parseObject(str, HashMap.class);
- str = null;
- for (Map.Entry<String, List<String>> entry : map.entrySet()) {
- try {
- stockRestPojo = new StockRestPojo();
- stockRestPojo.setDate(String.valueOf(entry.getValue().get(0)));
- if(String.valueOf(entry.getValue().get(1)).equals("0")){
- continue;
- }
- stockRestPojo.setTime(String.valueOf(entry.getValue().get(1)));
- stockRestPojo.setNow(String.valueOf(entry.getValue().get(2)));
- stockRestPojo.setHigh(String.valueOf(entry.getValue().get(3)));
- stockRestPojo.setLow(String.valueOf(entry.getValue().get(4)));
- stockRestPojo.setOpen(String.valueOf(entry.getValue().get(5)));
- stockRestPojo.setPreclose(String.valueOf(entry.getValue().get(6)));
- stockRestPojo.setRoundlot(String.valueOf(entry.getValue().get(7)));
- stockRestPojo.setChange(String.valueOf(entry.getValue().get(8)));
- stockRestPojo.setPctchange(String.valueOf(entry.getValue().get(9)));
- stockRestPojo.setVolume(String.valueOf(entry.getValue().get(10)));
- stockRestPojo.setAmount(String.valueOf(entry.getValue().get(11)));
- stockRestPojo.setVolumeratio(String.valueOf(entry.getValue().get(12)));
- stockRestPojo.setCommissionratio(String.valueOf(entry.getValue().get(13)));
- stockRestPojo.setCommissiondiff(String.valueOf(entry.getValue().get(14)));
- stockRestPojo.setTradestatus(String.valueOf(entry.getValue().get(15)));
- stockRestPojo.setOutvolume(String.valueOf(entry.getValue().get(16)));
- stockRestPojo.setInvolume(String.valueOf(entry.getValue().get(17)));
- stockRestPojo.setHighlimit(String.valueOf(entry.getValue().get(18)));
- stockRestPojo.setLowlimit(String.valueOf(entry.getValue().get(19)));
- stockRestPojo.setSpeed(String.valueOf(entry.getValue().get(20)));
- stockRestPojo.setAverageprice(String.valueOf(entry.getValue().get(21)));
- stockRestPojo.setBuyprice1(String.valueOf(entry.getValue().get(22)));
- stockRestPojo.setBuyprice2(String.valueOf(entry.getValue().get(23)));
- stockRestPojo.setBuyprice3(String.valueOf(entry.getValue().get(24)));
- stockRestPojo.setBuyprice4(String.valueOf(entry.getValue().get(25)));
- stockRestPojo.setBuyprice5(String.valueOf(entry.getValue().get(26)));
- stockRestPojo.setBuyvolume1(String.valueOf(entry.getValue().get(27)));
- stockRestPojo.setBuyvolume2(String.valueOf(entry.getValue().get(28)));
- stockRestPojo.setBuyvolume3(String.valueOf(entry.getValue().get(29)));
- stockRestPojo.setBuyvolume4(String.valueOf(entry.getValue().get(30)));
- stockRestPojo.setBuyvolume5(String.valueOf(entry.getValue().get(31)));
- stockRestPojo.setSellprice1(String.valueOf(entry.getValue().get(32)));
- stockRestPojo.setSellprice2(String.valueOf(entry.getValue().get(33)));
- stockRestPojo.setSellprice3(String.valueOf(entry.getValue().get(34)));
- stockRestPojo.setSellprice4(String.valueOf(entry.getValue().get(35)));
- stockRestPojo.setSellprice5(String.valueOf(entry.getValue().get(36)));
- stockRestPojo.setSellvolume1(String.valueOf(entry.getValue().get(37)));
- stockRestPojo.setSellvolume2(String.valueOf(entry.getValue().get(38)));
- stockRestPojo.setSellvolume3(String.valueOf(entry.getValue().get(39)));
- stockRestPojo.setSellvolume4(String.valueOf(entry.getValue().get(40)));
- stockRestPojo.setSellvolume5(String.valueOf(entry.getValue().get(41)));
- stockRestPojo.setClosedtime(String.valueOf(entry.getValue().get(42)));
- stockRestPojo.setClosedvolume(String.valueOf(entry.getValue().get(43)));
- stockRestPojo.setClosedamount(String.valueOf(entry.getValue().get(44)));
- StringBuffer dateStr = new StringBuffer(stockRestPojo.getDate());
- if (StringUtils.isEmpty(stockRestPojo.getTime())) {
- dateStr = dateStr.append(000000);
- } else {
- dateStr.append( String.format("%06d", Integer.parseInt(stockRestPojo.getTime())));
- // if (5 == stockRestPojo.getTime().length()) {
- // // 长度为5表示 小时前面需要补0
- // dateStr = dateStr.append(0).append(stockRestPojo.getTime());
- // } else {
- // dateStr = dateStr.append(stockRestPojo.getTime());
- // }
- }
- Date date = TimeUtil.strToDate(dateStr.toString());
- // 毫秒转成秒
- stockRestPojo.setRealTime(date.getTime() / 1000);
- Calendar calendar = Calendar.getInstance();
- calendar.setTime(date);
- int min = calendar.get(Calendar.MINUTE); // 获取分钟
- int sec = calendar.get(Calendar.SECOND); // 获取秒数
- // 1分钟数据
- if (sec != 0) {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime() + 60 - sec);
- } else {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime());
- }
- // 5分钟数据
- if (sec != 0 || min % 5 != 0) {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime() + (5 * 60) - sec - (min % 5 * 60));
- } else {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime());
- }
- // 15分钟数据
- if (sec != 0 || min % 15 != 0) {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime() + (15 * 60) - sec - (min % 15 * 60));
- } else {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime());
- }
- // 30分钟数据
- if (sec != 0 || min % 30 != 0) {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime() + (30 * 60) - sec - (min % 30 * 60));
- } else {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime());
- }
- // 60分钟数据
- if (sec != 0 || min % 60 != 0) {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime() + (60 * 60) - sec - (min % 60 * 60));
- } else {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime());
- }
- StringBuffer tableName = new StringBuffer("data_rt_");
- tableName.append(entry.getKey().replace(".", "_").toLowerCase());
- stockRestPojo.setCode(entry.getKey().toUpperCase());
- stockRestPojo.setTableName(tableName.toString());
- if(new BigDecimal(stockRestPojo.getNow()+"").compareTo(BigDecimal.ZERO)!=0) {
- stockRestPojoList.add(stockRestPojo);
- stockRestVO = new StockRestVO();
- BeanUtils.copyProperties(stockRestPojo, stockRestVO);
- stockRestVOList.add(stockRestVO);
- stockRestRedisVO = new StockRestRedisVO();
- stockRestRedisVO.setCode(entry.getKey().toUpperCase());
- stockRestRedisVO.setNowPrice(stockRestPojo.getNow());
- stockRestRedisVO.setChange(stockRestPojo.getChange());
- stockRestRedisVO.setHcrate(stockRestPojo.getPctchange());
- stockRestRedisVO.setHighlimit(stockRestPojo.getHighlimit());
- stockRestRedisVO.setLowlimit(stockRestPojo.getLowlimit());
- stockRestRedisVO.setBuy1(stockRestPojo.getBuyprice1());
- stockRestRedisVO.setBuy2(stockRestPojo.getBuyprice2());
- stockRestRedisVO.setBuy3(stockRestPojo.getBuyprice3());
- stockRestRedisVO.setBuy4(stockRestPojo.getBuyprice4());
- stockRestRedisVO.setBuy5(stockRestPojo.getBuyprice5());
- stockRestRedisVO.setSell1(stockRestPojo.getSellprice1());
- stockRestRedisVO.setSell2(stockRestPojo.getSellprice2());
- stockRestRedisVO.setSell3(stockRestPojo.getSellprice3());
- stockRestRedisVO.setSell4(stockRestPojo.getSellprice4());
- stockRestRedisVO.setSell5(stockRestPojo.getSellprice5());
- stockRestRedisVO.setBuy1_num(stockRestPojo.getBuyvolume1());
- stockRestRedisVO.setBuy2_num(stockRestPojo.getBuyvolume2());
- stockRestRedisVO.setBuy3_num(stockRestPojo.getBuyvolume3());
- stockRestRedisVO.setBuy4_num(stockRestPojo.getBuyvolume4());
- stockRestRedisVO.setBuy5_num(stockRestPojo.getBuyvolume5());
- stockRestRedisVO.setSell1_num(stockRestPojo.getSellvolume1());
- stockRestRedisVO.setSell2_num(stockRestPojo.getSellvolume2());
- stockRestRedisVO.setSell3_num(stockRestPojo.getSellvolume3());
- stockRestRedisVO.setSell4_num(stockRestPojo.getSellvolume4());
- stockRestRedisVO.setSell5_num(stockRestPojo.getSellvolume5());
- redisUtil.saveItem("stock_"+stockRestRedisVO.getCode(),JSON.toJSONString(stockRestRedisVO), 10, TimeUnit.DAYS);
- // stockRestRedisVOList.add(stockRestRedisVO);
- }
- }catch (Exception e){
- log.error("错误数据导致失败" + e);
- }
- }
- map = null;
- }
- // 5.入库
- insertList(stockRestPojoList, stockRestVOList, stockRestRedisVOList,type);
- stockRestPojoList = null;
- }
- @Override
- public void analysisStockRestDataAfter(String type) {
- // 1.获取文件夹文件 按照时间顺序拿到一个
- List<File> files = FileStockUtil.getFile(sourceAfterFileUrl);
- if(null == files || 0 == files.size()){
- return;
- }
- List<StockRestPojo> stockRestPojoList = new ArrayList<>();
- List<StockRestVO> stockRestVOList = new ArrayList<>();
- List<StockRestRedisVO> stockRestRedisVOList = new ArrayList<>();
- StockRestPojo stockRestPojo;
- StockRestVO stockRestVO;
- StockRestRedisVO stockRestRedisVO;
- for (File file : files){
- // 2.移动文件去另外一个文件夹
- FileStockUtil.moveFile(sourceAfterFileUrl + File.separator + file.getName(), goalAfterFileUrl);
- // 3.读取文件内容
- String str = FileStockUtil.readFileContent(goalAfterFileUrl + File.separator + file.getName());
- // 4.并解析
- if(StringUtils.isEmpty(str)){
- continue;
- }
- Map<String, List<String>> map = new HashMap<String, List<String>>();
- map = JSON.parseObject(str, HashMap.class);
- str = null;
- for (Map.Entry<String, List<String>> entry : map.entrySet()) {
- try {
- stockRestPojo = new StockRestPojo();
- stockRestPojo.setDate(String.valueOf(entry.getValue().get(0)));
- if(String.valueOf(entry.getValue().get(1)).equals("0")){
- continue;
- }
- stockRestPojo.setTime("150000");
- stockRestPojo.setNow(String.valueOf(entry.getValue().get(2)));
- stockRestPojo.setHigh(String.valueOf(entry.getValue().get(3)));
- stockRestPojo.setLow(String.valueOf(entry.getValue().get(4)));
- stockRestPojo.setOpen(String.valueOf(entry.getValue().get(5)));
- stockRestPojo.setPreclose(String.valueOf(entry.getValue().get(6)));
- stockRestPojo.setRoundlot(String.valueOf(entry.getValue().get(7)));
- stockRestPojo.setChange(String.valueOf(entry.getValue().get(8)));
- stockRestPojo.setPctchange(String.valueOf(entry.getValue().get(9)));
- stockRestPojo.setVolume(String.valueOf(entry.getValue().get(10)));
- stockRestPojo.setAmount(String.valueOf(entry.getValue().get(11)));
- stockRestPojo.setVolumeratio(String.valueOf(entry.getValue().get(12)));
- stockRestPojo.setCommissionratio(String.valueOf(entry.getValue().get(13)));
- stockRestPojo.setCommissiondiff(String.valueOf(entry.getValue().get(14)));
- stockRestPojo.setTradestatus(String.valueOf(entry.getValue().get(15)));
- stockRestPojo.setOutvolume(String.valueOf(entry.getValue().get(16)));
- stockRestPojo.setInvolume(String.valueOf(entry.getValue().get(17)));
- stockRestPojo.setHighlimit(String.valueOf(entry.getValue().get(18)));
- stockRestPojo.setLowlimit(String.valueOf(entry.getValue().get(19)));
- stockRestPojo.setSpeed(String.valueOf(entry.getValue().get(20)));
- stockRestPojo.setAverageprice(String.valueOf(entry.getValue().get(21)));
- stockRestPojo.setBuyprice1(String.valueOf(entry.getValue().get(22)));
- stockRestPojo.setBuyprice2(String.valueOf(entry.getValue().get(23)));
- stockRestPojo.setBuyprice3(String.valueOf(entry.getValue().get(24)));
- stockRestPojo.setBuyprice4(String.valueOf(entry.getValue().get(25)));
- stockRestPojo.setBuyprice5(String.valueOf(entry.getValue().get(26)));
- stockRestPojo.setBuyvolume1(String.valueOf(entry.getValue().get(27)));
- stockRestPojo.setBuyvolume2(String.valueOf(entry.getValue().get(28)));
- stockRestPojo.setBuyvolume3(String.valueOf(entry.getValue().get(29)));
- stockRestPojo.setBuyvolume4(String.valueOf(entry.getValue().get(30)));
- stockRestPojo.setBuyvolume5(String.valueOf(entry.getValue().get(31)));
- stockRestPojo.setSellprice1(String.valueOf(entry.getValue().get(32)));
- stockRestPojo.setSellprice2(String.valueOf(entry.getValue().get(33)));
- stockRestPojo.setSellprice3(String.valueOf(entry.getValue().get(34)));
- stockRestPojo.setSellprice4(String.valueOf(entry.getValue().get(35)));
- stockRestPojo.setSellprice5(String.valueOf(entry.getValue().get(36)));
- stockRestPojo.setSellvolume1(String.valueOf(entry.getValue().get(37)));
- stockRestPojo.setSellvolume2(String.valueOf(entry.getValue().get(38)));
- stockRestPojo.setSellvolume3(String.valueOf(entry.getValue().get(39)));
- stockRestPojo.setSellvolume4(String.valueOf(entry.getValue().get(40)));
- stockRestPojo.setSellvolume5(String.valueOf(entry.getValue().get(41)));
- stockRestPojo.setClosedtime(String.valueOf(entry.getValue().get(42)));
- stockRestPojo.setClosedvolume(String.valueOf(entry.getValue().get(43)));
- stockRestPojo.setClosedamount(String.valueOf(entry.getValue().get(44)));
- StringBuffer dateStr = new StringBuffer(stockRestPojo.getDate());
- if (StringUtils.isEmpty(stockRestPojo.getTime())) {
- dateStr = dateStr.append(000000);
- } else {
- if (5 == stockRestPojo.getTime().length()) {
- // 长度为5表示 小时前面需要补0
- dateStr = dateStr.append(0).append(stockRestPojo.getTime());
- } else {
- dateStr = dateStr.append(stockRestPojo.getTime());
- }
- }
- Date date = TimeUtil.strToDate(dateStr.toString());
- // 毫秒转成秒
- stockRestPojo.setRealTime(date.getTime() / 1000);
- Calendar calendar = Calendar.getInstance();
- calendar.setTime(date);
- int min = calendar.get(Calendar.MINUTE); // 获取分钟
- int sec = calendar.get(Calendar.SECOND); // 获取秒数
- // 1分钟数据
- if (sec != 0) {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime() + 60 - sec);
- } else {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime());
- }
- // 5分钟数据
- if (sec != 0 || min % 5 != 0) {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime() + (5 * 60) - sec - (min % 5 * 60));
- } else {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime());
- }
- // 15分钟数据
- if (sec != 0 || min % 15 != 0) {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime() + (15 * 60) - sec - (min % 15 * 60));
- } else {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime());
- }
- // 30分钟数据
- if (sec != 0 || min % 30 != 0) {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime() + (30 * 60) - sec - (min % 30 * 60));
- } else {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime());
- }
- // 60分钟数据
- if (sec != 0 || min % 60 != 0) {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime() + (60 * 60) - sec - (min % 60 * 60));
- } else {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime());
- }
- StringBuffer tableName = new StringBuffer("data_rt_");
- tableName.append(entry.getKey().replace(".", "_").toLowerCase());
- stockRestPojo.setCode(entry.getKey().toUpperCase());
- stockRestPojo.setTableName(tableName.toString());
- if(new BigDecimal(stockRestPojo.getNow()+"").compareTo(BigDecimal.ZERO)!=0) {
- stockRestPojo.setRealTime((System.currentTimeMillis() / 1000));
- stockRestPojoList.add(stockRestPojo);
- stockRestVO = new StockRestVO();
- BeanUtils.copyProperties(stockRestPojo, stockRestVO);
- stockRestVOList.add(stockRestVO);
- stockRestRedisVO = new StockRestRedisVO();
- stockRestRedisVO.setCode(entry.getKey().toUpperCase());
- stockRestRedisVO.setNowPrice(stockRestPojo.getNow());
- stockRestRedisVO.setChange(stockRestPojo.getChange());
- stockRestRedisVO.setHcrate(stockRestPojo.getPctchange());
- stockRestRedisVO.setHighlimit(stockRestPojo.getHighlimit());
- stockRestRedisVO.setLowlimit(stockRestPojo.getLowlimit());
- stockRestRedisVO.setBuy1(stockRestPojo.getBuyprice1());
- stockRestRedisVO.setBuy2(stockRestPojo.getBuyprice2());
- stockRestRedisVO.setBuy3(stockRestPojo.getBuyprice3());
- stockRestRedisVO.setBuy4(stockRestPojo.getBuyprice4());
- stockRestRedisVO.setBuy5(stockRestPojo.getBuyprice5());
- stockRestRedisVO.setSell1(stockRestPojo.getSellprice1());
- stockRestRedisVO.setSell2(stockRestPojo.getSellprice2());
- stockRestRedisVO.setSell3(stockRestPojo.getSellprice3());
- stockRestRedisVO.setSell4(stockRestPojo.getSellprice4());
- stockRestRedisVO.setSell5(stockRestPojo.getSellprice5());
- stockRestRedisVO.setBuy1_num(stockRestPojo.getBuyvolume1());
- stockRestRedisVO.setBuy2_num(stockRestPojo.getBuyvolume2());
- stockRestRedisVO.setBuy3_num(stockRestPojo.getBuyvolume3());
- stockRestRedisVO.setBuy4_num(stockRestPojo.getBuyvolume4());
- stockRestRedisVO.setBuy5_num(stockRestPojo.getBuyvolume5());
- stockRestRedisVO.setSell1_num(stockRestPojo.getSellvolume1());
- stockRestRedisVO.setSell2_num(stockRestPojo.getSellvolume2());
- stockRestRedisVO.setSell3_num(stockRestPojo.getSellvolume3());
- stockRestRedisVO.setSell4_num(stockRestPojo.getSellvolume4());
- stockRestRedisVO.setSell5_num(stockRestPojo.getSellvolume5());
- redisUtil.saveItem("stock_"+stockRestRedisVO.getCode(),JSON.toJSONString(stockRestRedisVO), 10, TimeUnit.DAYS);
- // stockRestRedisVOList.add(stockRestRedisVO);
- }
- }catch (Exception e){
- log.error("错误数据导致失败" + e);
- }
- }
- map = null;
- }
- // 5.入库
- insertListAfter(stockRestPojoList, stockRestVOList, stockRestRedisVOList,type);
- stockRestPojoList = null;
- }
- private void insertList(List<StockRestPojo> list, List<StockRestVO> stockRestVOList, List<StockRestRedisVO> stockRestRedisVOList,String type) {
- int insertLength = list.size();
- int i = 0;
- int insertSize = 500;
- while (insertLength > insertSize) {
- choiceStockMapper.insertBatch(list.subList(i, i + insertSize));
- // List<StockRestVO> subList = stockRestVOList.subList(i, i + insertSize);
- // List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertSize);
- i = i + insertSize;
- insertLength = insertLength - insertSize;
- // Thread thread=new Thread(new Runnable() {
- // @Override
- // public void run() {
- //// HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- //// if(BuyAndSellUtils.isTransState()){
- // try {
- // new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- //
- //// HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- // }catch (Exception e){
- // log.error("插入redis错误" + e);
- // }
- //// }
- //
- // }
- // });
- // thread.start();
- }
- if (insertLength > 0) {
- choiceStockMapper.insertBatch(list.subList(i, i + insertLength));
- // List<StockRestVO> subList = stockRestVOList.subList(i, i + insertLength);
- // List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertLength);
- // Thread thread=new Thread(new Runnable() {
- // @Override
- // public void run() {
- //// HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- //// if(BuyAndSellUtils.isTransState()){
- // try {
- // new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- //// HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- // }catch (Exception e){
- // log.error("插入redis错误" + e);
- // }
- //// }
- // }
- // });
- // thread.start();
- }
- }
- private void insertListAfter(List<StockRestPojo> list, List<StockRestVO> stockRestVOList, List<StockRestRedisVO> stockRestRedisVOList,String type) {
- int insertLength = list.size();
- int i = 0;
- int insertSize = 500;
- while (insertLength > insertSize) {
- choiceStockMapper.insertBatchByAfter(list.subList(i, i + insertSize));
- // List<StockRestVO> subList = stockRestVOList.subList(i, i + insertSize);
- // List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertSize);
- i = i + insertSize;
- insertLength = insertLength - insertSize;
- // Thread thread=new Thread(new Runnable() {
- // @Override
- // public void run() {
- //// HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- //// if(BuyAndSellUtils.isTransState()){
- // try {
- // new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- //// HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- // }catch (Exception e){
- // log.error("插入redis错误" + e);
- // }
- //// }
- //
- // }
- // });
- // thread.start();
- }
- if (insertLength > 0) {
- choiceStockMapper.insertBatchByAfter(list.subList(i, i + insertLength));
- // List<StockRestVO> subList = stockRestVOList.subList(i, i + insertLength);
- // List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertLength);
- // Thread thread=new Thread(new Runnable() {
- // @Override
- // public void run() {
- //// HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- //// if(BuyAndSellUtils.isTransState()){
- // try {
- // new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- //// HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- // }catch (Exception e){
- // log.error("插入redis错误" + e);
- // }
- //// }
- // }
- // });
- // thread.start();
- }
- }
- @Override
- public void analysisStockRestDataInFront(String type) {
- // 1.获取文件夹文件 按照时间顺序拿到一个
- List<File> files = FileStockUtil.getFile(sourceFileUrlInFront);
- if(null == files || 0 == files.size()){
- return;
- }
- List<StockRestPojo> stockRestPojoList = new ArrayList<>();
- List<StockRestVO> stockRestVOList = new ArrayList<>();
- List<StockRestRedisVO> stockRestRedisVOList = new ArrayList<>();
- StockRestPojo stockRestPojo;
- StockRestVO stockRestVO;
- StockRestRedisVO stockRestRedisVO;
- for (File file : files){
- // 2.移动文件去另外一个文件夹
- FileStockUtil.moveFile(sourceFileUrlInFront + File.separator + file.getName(), goalFileUrlInFront);
- // 3.读取文件内容
- String str = FileStockUtil.readFileContent(goalFileUrlInFront + File.separator + file.getName());
- // 4.并解析
- if(StringUtils.isEmpty(str)){
- continue;
- }
- Map<String, List<String>> map = new HashMap<String, List<String>>();
- map = JSON.parseObject(str, HashMap.class);
- str = null;
- for (Map.Entry<String, List<String>> entry : map.entrySet()) {
- try {
- stockRestPojo = new StockRestPojo();
- stockRestPojo.setDate(String.valueOf(entry.getValue().get(0)));
- if(String.valueOf(entry.getValue().get(1)).equals("0")){
- continue;
- }
- stockRestPojo.setTime(String.valueOf(entry.getValue().get(1)));
- stockRestPojo.setNow(String.valueOf(entry.getValue().get(2)));
- stockRestPojo.setHigh(String.valueOf(entry.getValue().get(3)));
- stockRestPojo.setLow(String.valueOf(entry.getValue().get(4)));
- stockRestPojo.setOpen(String.valueOf(entry.getValue().get(5)));
- stockRestPojo.setPreclose(String.valueOf(entry.getValue().get(6)));
- stockRestPojo.setRoundlot(String.valueOf(entry.getValue().get(7)));
- stockRestPojo.setChange(String.valueOf(entry.getValue().get(8)));
- stockRestPojo.setPctchange(String.valueOf(entry.getValue().get(9)));
- stockRestPojo.setVolume(String.valueOf(entry.getValue().get(10)));
- stockRestPojo.setAmount(String.valueOf(entry.getValue().get(11)));
- stockRestPojo.setVolumeratio(String.valueOf(entry.getValue().get(12)));
- stockRestPojo.setCommissionratio(String.valueOf(entry.getValue().get(13)));
- stockRestPojo.setCommissiondiff(String.valueOf(entry.getValue().get(14)));
- stockRestPojo.setTradestatus(String.valueOf(entry.getValue().get(15)));
- stockRestPojo.setOutvolume(String.valueOf(entry.getValue().get(16)));
- stockRestPojo.setInvolume(String.valueOf(entry.getValue().get(17)));
- stockRestPojo.setHighlimit(String.valueOf(entry.getValue().get(18)));
- stockRestPojo.setLowlimit(String.valueOf(entry.getValue().get(19)));
- stockRestPojo.setSpeed(String.valueOf(entry.getValue().get(20)));
- stockRestPojo.setAverageprice(String.valueOf(entry.getValue().get(21)));
- stockRestPojo.setBuyprice1(String.valueOf(entry.getValue().get(22)));
- stockRestPojo.setBuyprice2(String.valueOf(entry.getValue().get(23)));
- stockRestPojo.setBuyprice3(String.valueOf(entry.getValue().get(24)));
- stockRestPojo.setBuyprice4(String.valueOf(entry.getValue().get(25)));
- stockRestPojo.setBuyprice5(String.valueOf(entry.getValue().get(26)));
- stockRestPojo.setBuyvolume1(String.valueOf(entry.getValue().get(27)));
- stockRestPojo.setBuyvolume2(String.valueOf(entry.getValue().get(28)));
- stockRestPojo.setBuyvolume3(String.valueOf(entry.getValue().get(29)));
- stockRestPojo.setBuyvolume4(String.valueOf(entry.getValue().get(30)));
- stockRestPojo.setBuyvolume5(String.valueOf(entry.getValue().get(31)));
- stockRestPojo.setSellprice1(String.valueOf(entry.getValue().get(32)));
- stockRestPojo.setSellprice2(String.valueOf(entry.getValue().get(33)));
- stockRestPojo.setSellprice3(String.valueOf(entry.getValue().get(34)));
- stockRestPojo.setSellprice4(String.valueOf(entry.getValue().get(35)));
- stockRestPojo.setSellprice5(String.valueOf(entry.getValue().get(36)));
- stockRestPojo.setSellvolume1(String.valueOf(entry.getValue().get(37)));
- stockRestPojo.setSellvolume2(String.valueOf(entry.getValue().get(38)));
- stockRestPojo.setSellvolume3(String.valueOf(entry.getValue().get(39)));
- stockRestPojo.setSellvolume4(String.valueOf(entry.getValue().get(40)));
- stockRestPojo.setSellvolume5(String.valueOf(entry.getValue().get(41)));
- stockRestPojo.setClosedtime(String.valueOf(entry.getValue().get(42)));
- stockRestPojo.setClosedvolume(String.valueOf(entry.getValue().get(43)));
- stockRestPojo.setClosedamount(String.valueOf(entry.getValue().get(44)));
- StringBuffer dateStr = new StringBuffer(stockRestPojo.getDate());
- if (StringUtils.isEmpty(stockRestPojo.getTime())) {
- dateStr = dateStr.append(000000);
- } else {
- if (5 == stockRestPojo.getTime().length()) {
- // 长度为5表示 小时前面需要补0
- dateStr = dateStr.append(0).append(stockRestPojo.getTime());
- } else {
- dateStr = dateStr.append(stockRestPojo.getTime());
- }
- }
- Date date = TimeUtil.strToDate(dateStr.toString());
- // 毫秒转成秒
- stockRestPojo.setRealTime(date.getTime() / 1000);
- Calendar calendar = Calendar.getInstance();
- calendar.setTime(date);
- int min = calendar.get(Calendar.MINUTE); // 获取分钟
- int sec = calendar.get(Calendar.SECOND); // 获取秒数
- // 1分钟数据
- if (sec != 0) {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime() + 60 - sec);
- } else {
- stockRestPojo.setDateOne(stockRestPojo.getRealTime());
- }
- // 5分钟数据
- if (sec != 0 || min % 5 != 0) {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime() + (5 * 60) - sec - (min % 5 * 60));
- } else {
- stockRestPojo.setDateFive(stockRestPojo.getRealTime());
- }
- // 15分钟数据
- if (sec != 0 || min % 15 != 0) {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime() + (15 * 60) - sec - (min % 15 * 60));
- } else {
- stockRestPojo.setDateFifteen(stockRestPojo.getRealTime());
- }
- // 30分钟数据
- if (sec != 0 || min % 30 != 0) {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime() + (30 * 60) - sec - (min % 30 * 60));
- } else {
- stockRestPojo.setDateThirty(stockRestPojo.getRealTime());
- }
- // 60分钟数据
- if (sec != 0 || min % 60 != 0) {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime() + (60 * 60) - sec - (min % 60 * 60));
- } else {
- stockRestPojo.setDateSixty(stockRestPojo.getRealTime());
- }
- StringBuffer tableName = new StringBuffer("data_rt_");
- tableName.append(entry.getKey().replace(".", "_").toLowerCase());
- stockRestPojo.setCode(entry.getKey().toUpperCase());
- stockRestPojo.setTableName(tableName.toString());
- if(new BigDecimal(stockRestPojo.getNow()+"").compareTo(BigDecimal.ZERO)!=0) {
- stockRestPojoList.add(stockRestPojo);
- stockRestVO = new StockRestVO();
- BeanUtils.copyProperties(stockRestPojo, stockRestVO);
- stockRestVOList.add(stockRestVO);
- stockRestRedisVO = new StockRestRedisVO();
- stockRestRedisVO.setCode(entry.getKey().toUpperCase());
- stockRestRedisVO.setNowPrice(stockRestPojo.getNow());
- stockRestRedisVO.setChange(stockRestPojo.getChange());
- stockRestRedisVO.setHcrate(stockRestPojo.getPctchange());
- stockRestRedisVO.setHighlimit(stockRestPojo.getHighlimit());
- stockRestRedisVO.setLowlimit(stockRestPojo.getLowlimit());
- stockRestRedisVO.setBuy1(stockRestPojo.getBuyprice1());
- stockRestRedisVO.setBuy2(stockRestPojo.getBuyprice2());
- stockRestRedisVO.setBuy3(stockRestPojo.getBuyprice3());
- stockRestRedisVO.setBuy4(stockRestPojo.getBuyprice4());
- stockRestRedisVO.setBuy5(stockRestPojo.getBuyprice5());
- stockRestRedisVO.setSell1(stockRestPojo.getSellprice1());
- stockRestRedisVO.setSell2(stockRestPojo.getSellprice2());
- stockRestRedisVO.setSell3(stockRestPojo.getSellprice3());
- stockRestRedisVO.setSell4(stockRestPojo.getSellprice4());
- stockRestRedisVO.setSell5(stockRestPojo.getSellprice5());
- stockRestRedisVO.setBuy1_num(stockRestPojo.getBuyvolume1());
- stockRestRedisVO.setBuy2_num(stockRestPojo.getBuyvolume2());
- stockRestRedisVO.setBuy3_num(stockRestPojo.getBuyvolume3());
- stockRestRedisVO.setBuy4_num(stockRestPojo.getBuyvolume4());
- stockRestRedisVO.setBuy5_num(stockRestPojo.getBuyvolume5());
- stockRestRedisVO.setSell1_num(stockRestPojo.getSellvolume1());
- stockRestRedisVO.setSell2_num(stockRestPojo.getSellvolume2());
- stockRestRedisVO.setSell3_num(stockRestPojo.getSellvolume3());
- stockRestRedisVO.setSell4_num(stockRestPojo.getSellvolume4());
- stockRestRedisVO.setSell5_num(stockRestPojo.getSellvolume5());
- redisUtil.saveItem("stock_"+stockRestRedisVO.getCode(),JSON.toJSONString(stockRestRedisVO), 10, TimeUnit.DAYS);
- // stockRestRedisVOList.add(stockRestRedisVO);
- }
- }catch (Exception e){
- log.error("错误数据导致失败" + e);
- }
- }
- map = null;
- }
- // 5.入库
- insertListInFront(stockRestPojoList, stockRestVOList, stockRestRedisVOList,type);
- stockRestPojoList = null;
- }
- private void insertListInFront(List<StockRestPojo> list, List<StockRestVO> stockRestVOList, List<StockRestRedisVO> stockRestRedisVOList,String type) {
- int insertLength = list.size();
- int i = 0;
- int insertSize = 500;
- while (insertLength > insertSize) {
- choiceStockMapper.insertBatch(list.subList(i, i + insertSize));
- List<StockRestVO> subList = stockRestVOList.subList(i, i + insertSize);
- List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertSize);
- i = i + insertSize;
- insertLength = insertLength - insertSize;
- Thread thread=new Thread(new Runnable() {
- @Override
- public void run() {
- // HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- // if(BuyAndSellUtils.isTransState()){
- try {
- new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- // HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- }catch (Exception e){
- log.error("插入redis错误" + e);
- }
- // }
- }
- });
- thread.start();
- }
- if (insertLength > 0) {
- choiceStockMapper.insertBatch(list.subList(i, i + insertLength));
- List<StockRestVO> subList = stockRestVOList.subList(i, i + insertLength);
- List<StockRestRedisVO> subRedisList = stockRestRedisVOList.subList(i, i + insertLength);
- Thread thread=new Thread(new Runnable() {
- @Override
- public void run() {
- // HttpRequest.httpPostWithjson(url, JSON.toJSONString(subList));
- // if(BuyAndSellUtils.isTransState()){
- try {
- new WebSocketController().sendSysMsgType("GP",JSON.toJSONString(subRedisList));
- // HttpRequest.httpPostWithjson(urlRedis, JSON.toJSONString(subRedisList));
- }catch (Exception e){
- log.error("插入redis错误" + e);
- }
- // }
- }
- });
- thread.start();
- }
- }
- }
|