Пример #1
0
        /// <summary>
        /// 生成遗漏图表,生成当前term数据及以后数据
        /// by JNswins 2015-06-10
        /// </summary>
        /// <param name="chartId">遗漏表ID</param>
        /// <param name="term">需要生成走势图期数</param>
        /// <param name="fields">彩种开奖数据额外查询条件</param>
        /// <returns></returns>
        public static Tuple <bool, string> CreateMissData(int chartId, long term, LotterySearchField fields = null)
        {
            //读取遗漏配置
            var trendMissItem = TrendMissItemService.GetMissEntity(chartId);

            if (null == trendMissItem)
            {
                return(new Tuple <bool, string>(false, string.Format("未找到【ChartId={0}】遗漏图的项配置数据", chartId)));
            }

            var ListToEnd = FC3DService.GetListToEnd(term, fields);

            if (null == ListToEnd || ListToEnd.Count <= 0)
            {
                return(new Tuple <bool, string>(false, "未找到有效开奖数据"));
            }

            //初始化项
            IMissItem <QG_FC3D> missItem = TrendMissUtils.GetTrendMissClassName <QG_FC3D>(trendMissItem.ClassName);
            int  i   = 0;
            bool yes = true;

            foreach (var item in ListToEnd)
            {
                //根据参数term期数获取近两期开奖信息TOP 2 [Term]<=term  ORDER BY [Term] DESC
                var     list = FC3DService.ToListForTrend(item.Term, fields);
                QG_FC3D info = null;
                IList <TrendMissDataInfo> missDataList = null;
                if (null == list || 0 >= list.Count)
                {
                    continue;
                }
                info = list[0];
                if (2 == list.Count)
                {
                    //取当前期数的上一期的遗漏数据
                    if (0 == i)
                    {
                        missDataList = TrendMissDataService.GetMissDataList(chartId, list[1].Term);
                    }
                    else
                    {
                        missDataList = missItem.GetMissDataList();
                    }
                }
                missItem.Init(trendMissItem, missDataList);
                yes = yes && missItem.SetItemValue(info);
                if (!yes)
                {
                    return(new Tuple <bool, string>(false, string.Format("开奖号错误:截止期数【term={0}】", item.Term)));
                }
                yes = yes && missItem.SaveData();
                if (!yes)
                {
                    return(new Tuple <bool, string>(false, string.Format("数据保存出错:截止期数【term={0}】", item.Term)));
                }
            }
            return(new Tuple <bool, string>(false, string.Format("生成遗漏成功:截止期数【term={0}】", ListToEnd[ListToEnd.Count - 1].Term)));
        }
Пример #2
0
        /// <summary>
        /// 预览遗漏数据
        /// </summary>
        /// <param name="chartId"></param>
        /// <param name="term"></param>
        /// <returns></returns>
        public static string PreViewMissData(int chartId, LotterySearchField fields = null)
        {
            StringBuilder sb            = new StringBuilder(20000);
            var           trendMissItem = TrendMissItemService.GetMissEntity(chartId);

            if (null == trendMissItem)
            {
                return("");
            }

            IMissItem <QG_FC3D> missItem = TrendMissUtils.GetTrendMissClassName <QG_FC3D>(trendMissItem.ClassName);
            var     list = FC3DService.GetListToEnd(0, fields);
            QG_FC3D info = null;
            IList <TrendMissDataInfo> missDataList = null;

            if (null == list || 0 >= list.Count)
            {
                return("");
            }

            bool yes = true;

            for (int i = 0; i < list.Count; i++)
            {
                info = list[i];

                missItem.Init(trendMissItem, missDataList);
                yes          = yes && missItem.SetItemValue(info);
                missDataList = missItem.GetMissDataList();
                if (!yes || i == list.Count - 1) //开奖号码不正确或者最后一条数据的时候显示数据
                {
                    if (null != missDataList)
                    {
                        foreach (var item in missDataList)
                        {
                            sb.Append("<tr>");
                            sb.Append(string.Format("<td>{0}</td>", item.ItemValue));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.Cycle)));
                            sb.Append(string.Format("<td>{0}|{1}</td>", item.Times, item.TimesTheory));
                            sb.Append(string.Format("<td>{0}</td>", (string.Format("{0:F2}", item.Probability * 100)) + "%"));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.AvgMiss)));
                            sb.Append(string.Format("<td>{0}</td>", item.MaxMiss));
                            sb.Append(string.Format("<td>{0}</td>", item.LastMaxMiss));
                            sb.Append(string.Format("<td>{0}</td>", item.LastMiss));
                            sb.Append(string.Format("<td>{0}</td>", item.LocalMiss));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.AppearingProbability)));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.InvestmentValue)));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.CoveringProbability)));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.ContinuousProbability)));
                            sb.Append(string.Format("<td>{0}</td>", item.ContinuousMaxTimes));
                            sb.Append(string.Format("<td>{0}</td>", item.ContinuousMaxMiss));
                            sb.Append(string.Format("<td>{0}</td>", 0 == item.ContinuousTimes ? item.Times - 1 : item.ContinuousLocalMiss));
                            sb.Append(string.Format("<td>{0}</td>", string.Format("{0:F2}", item.ContinuousLocalProbability)));
                            sb.Append("</tr>");
                        }
                    }
                    break;
                }
            }
            return(sb.ToString());
        }
Пример #3
0
        /// <summary>
        /// 生成走势图,生成当前term数据及以后数据
        /// </summary>
        /// <param name="chartId">走势图ID</param>
        /// <param name="chartType">走势图类型</param>
        /// <param name="term">需要生成走势图期数</param>
        /// <param name="fields">彩种开奖数据额外查询条件</param>
        /// <returns></returns>
        public static Tuple <bool, string> CreateTrendChart(int chartId, TrendChartType chartType, long term, LotterySearchField fields = null)
        {
            //获取走势图项及配置数据
            var trendChartItem = TrendChartItemService.ToListByChartId(chartId, chartType);

            if (null == trendChartItem || 0 >= trendChartItem.Count)
            {
                return(new Tuple <bool, string>(false, string.Format("未找到【ChartId={0}】走势图的项配置数据", chartId)));
            }

            int count = trendChartItem.Count;
            IList <IChartItem <QG_FC3D> > chartItem = new List <IChartItem <QG_FC3D> >(count);
            IList <ChartCssConfigInfo>    cssConfig = new List <ChartCssConfigInfo>(count);

            foreach (var item in trendChartItem)
            {
                //实例化项类型
                chartItem.Add(TrendChartUtils.GetTrendChartInterface <QG_FC3D>(item.ClassName));
                //获取项CSS配置信息
                cssConfig.Add(ChartCssConfigService.Get(item.FuntionType, item.ChartCssId));
            }

            //各项初始化
            for (int i = 0; i < count; i++)
            {
                trendChartItem[i].Cid = Cid.GetLotteryCId();
                chartItem[i].Init(cssConfig[i], trendChartItem[i]);
            }

            //大于等于term开奖数据
            IList <QG_FC3D> listToEnd = FC3DService.GetListToEnd(term, fields);

            if (null == listToEnd || 0 >= listToEnd.Count)
            {
                return(new Tuple <bool, string>(false, "未找到有效开奖数据"));
            }

            int            j            = 0;
            TrendChartData entity       = null;
            TrendChartData resultEntity = new TrendChartData
            {
                ChartId    = chartId,
                Term       = term,
                ChartType  = chartType,
                LocalMiss  = new string[count],
                LastMiss   = new string[count],
                AllMaxMiss = new string[count],
                AllAvgMiss = new string[count],
                AllTimes   = new string[count]
            };

            foreach (QG_FC3D currentData in listToEnd)
            {
                //根据参数term期数获取近两期开奖信息TOP 2 [Term]<=term  ORDER BY [Term] DESC
                IList <QG_FC3D> list = FC3DService.ToListForTrend(currentData.Term, fields);

                QG_FC3D info = null;
                info = list[0];

                if (chartId == 10)// || chartId == 22
                {
                    if (info.OpenCode1 == -1 || info.OpenCode2 == -1 || info.OpenCode3 == -1)
                    {
                        var sjh = info.ShiJiHao;
                        if (!string.IsNullOrEmpty(sjh))
                        {
                            var opArr = sjh.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
                            //info.OpenCode1 = int.Parse(opArr[0]);
                            //info.OpenCode2 = int.Parse(opArr[1]);
                            //info.OpenCode3 = int.Parse(opArr[2]);
                            info.OpenCode[0] = int.Parse(opArr[0]);
                            info.OpenCode[1] = int.Parse(opArr[1]);
                            info.OpenCode[2] = int.Parse(opArr[2]);
                        }
                    }
                }
                if (2 == list.Count)
                {
                    //取当前期数的上一期的走势图信息及遗漏数据
                    entity = resultEntity;
                    if (0 == j)
                    {
                        entity = FC3DTrendChartDataService.GetTrendChartDataByTerm(chartId, chartType, list[1].Term);
                    }
                }

                bool yes = true;
                var  sp  = new StringBuilder(20000);
                sp.Append("<tr>");
                for (int i = 0; i < count; i++)
                {
                    //初始化遗漏数据(根据上期结果集计算_entity)
                    chartItem[i].MissDataInit(entity, i);
                    //计算项值及遗漏计算
                    yes = yes && chartItem[i].SetItemValue(info);

                    if (yes)
                    {
                        //结果集赋值
                        resultEntity.LocalMiss[i]  = chartItem[i].GetMissData(MissDataType.LocalMiss);
                        resultEntity.LastMiss[i]   = chartItem[i].GetMissData(MissDataType.LastMiss);
                        resultEntity.AllMaxMiss[i] = chartItem[i].GetMissData(MissDataType.AllMaxMiss);
                        resultEntity.AllAvgMiss[i] = chartItem[i].GetMissData(MissDataType.AllAvgMiss);
                        resultEntity.AllTimes[i]   = chartItem[i].GetMissData(MissDataType.AllTimes);

                        if (i == 1 && chartId == 10 && info.OpenCode1 == -1)
                        {
                            var singleValueItem = chartItem[i] as SingleValueItem <QG_FC3D>;
                            if (singleValueItem != null)
                            {
                                singleValueItem._itemValue = "&nbsp;";
                            }
                        }
                        sp.Append(chartItem[i].GetFomartString("<td {0}>{1}</td>"));
                    }
                }
                sp.Append("</tr>");
                if (null != entity)
                {
                    resultEntity.RecordCount = entity.RecordCount + 1;
                }
                else
                {
                    resultEntity.RecordCount = 1;
                }

                resultEntity.Term     = currentData.Term;
                resultEntity.HtmlData = sp.ToString();

                if (!yes)
                {
                    return(new Tuple <bool, string>(false, string.Format("无效开奖数据:数据生成截止期数为【term={0}】", resultEntity.Term)));
                }

                yes = yes && DatabaseProvider.GetDbProvider <IFC3DTrendChartDataService>().Save(resultEntity);
                if (!yes)
                {
                    return(new Tuple <bool, string>(false, string.Format("数据保存出错:数据保存截止期数为【term={0}】", resultEntity.Term)));
                }

                j++;
            }
            return(new Tuple <bool, string>(true, string.Format("正常生成完毕,截止期数为:Term={0}", listToEnd[listToEnd.Count - 1].Term)));
        }