/// <summary> /// 将此彩种指定期号和开奖号码保存至数据库 /// </summary> /// <param name="QiHao">期号</param> /// <param name="OpenCode">开奖号码(形如01,02,03)</param> /// <param name="IsYesterdayRecord">是否是保存昨天的记录</param> /// <returns></returns> private bool SaveRecord(BeiJingKZCEnitity data) { if (data == null) { return(false); } var model = new OpenCode9Model(); model.Term = Convert.ToInt64(data.QiHao); //期号 var haoMaArray = data.KaiJiangHao.Split(','); model.OpenCode1 = Convert.ToInt32(haoMaArray[0]); model.OpenCode2 = Convert.ToInt32(haoMaArray[1]); model.OpenCode3 = Convert.ToInt32(haoMaArray[2]); model.OpenCode4 = Convert.ToInt32(haoMaArray[3]); model.OpenCode5 = Convert.ToInt32(haoMaArray[4]); model.OpenCode6 = Convert.ToInt32(haoMaArray[5]); model.OpenCode7 = Convert.ToInt32(haoMaArray[6]); model.OpenCode8 = Convert.ToInt32(haoMaArray[7]); model.OpenCode9 = Convert.ToInt32(haoMaArray[8]); model.OpenTime = data.OpenTime; if (services.AddOpen9Code(currentLottery, model)) { GetMaxPeriodNum((int)model.Term); //添加成功存放期数 return(true); } return(false); }
/// 从主站抓取开奖数据 昨天/今天 /// </summary> /// <param name="IsToday"></param> /// <returns></returns> private List <BeiJingKZCEnitity> GetDocByMainUrl(bool IsToday = true) { var list = new List <BeiJingKZCEnitity>(); try { var time = DateTime.Now; var arg = new OpenCaiApiArg { code = EnumHelper.GetLotteryCode(SCCLottery.BeiJingKZC), // rows = int.Parse(GetPeriodsNumberToDay(time, IsToday)), date = time.ToString("yyyy-MM-dd") }; if (!IsToday) { arg.date = time.AddDays(-1).ToString("yyyy-MM-dd"); } var data = OpenCaiApiServices.GetOpenCaiApiData(arg); if (data == null) { return(list); } if (data.data != null) { if (data.data.Count == 0) { return(list); } for (var i = 0; i < data.data.Count; i++) { var tmp = new BeiJingKZCEnitity { QiHao = DateTime.Now.ToString("yyMMdd") + GetPeriodsNumberToDay(DateTime.Parse(data.data[i].opentime), true), KaiJiangHao = data.data[i].GetOpenCodeStr(), OpenTime = DateTime.Parse(data.data[i].opentime) }; list.Add(tmp); } var checkDataHelper = new CheckDataHelper(); var dbdata = services.GetListIn(currentLottery, IsToday) .ToDictionary(w => w.Term.ToString(), w => w.GetCodeStr()); checkDataHelper.CheckData(dbdata, list.ToDictionary(w => w.QiHao.ToString(), w => w.KaiJiangHao), Config.Area, currentLottery); } } catch (Exception ee) { log.Error(GetType(), string.Format("【{0}】通过站点抓取开奖列表时发生错误,错误信息【{1}】", Config.Area + currentLottery, ee.Message)); } return(list); }
/// <summary> /// 抓取站点开奖数据 /// </summary> /// <param name="url">备用站点</param> /// <returns></returns> private List <BeiJingKZCEnitity> GetDocByBackUrl(bool IsToday = true) { var list = new List <BeiJingKZCEnitity>(); try { var day = DateTime.Now.ToString("yyyyMMdd"); if (!IsToday) { day = DateTime.Now.AddDays(-1).ToString("yyyyMMdd"); } var url = string.Format(Config.BackUrl, day); //" http://kaijiang.500.com/static/info/kaijiang/xml/bjkzhc/20171124.xml?_A=YLQMBVJT1511764350898"; //string url = @"http://www.bwlc.net/bulletin/prevqck3.html?page=3"; var HtmlResource = NetHelper.GetUrlResponse(url); if (HtmlResource == null) { return(list); } var doc = new XmlDocument(); doc.LoadXml(HtmlResource); var records = doc.SelectNodes("//row"); if (records == null) { return(list); } foreach (XmlNode xmlnode in records) { if (xmlnode.Attributes["expect"] == null || string.IsNullOrWhiteSpace(xmlnode.Attributes["expect"].Value) || xmlnode.Attributes["opencode"] == null || string.IsNullOrWhiteSpace(xmlnode.Attributes["opencode"].Value)) { continue; } var num = xmlnode.Attributes["expect"].Value; var opencode = xmlnode.Attributes["opencode"].Value; var opentime = xmlnode.Attributes["opentime"].Value; var tmp = new BeiJingKZCEnitity { QiHao = num.Substring(2), KaiJiangHao = opencode, OpenTime = DateTime.Parse(opentime) }; list.Add(tmp); } var checkDataHelper = new CheckDataHelper(); var dbdata = services.GetListIn(currentLottery, IsToday) .ToDictionary(w => w.Term.ToString(), w => w.GetCodeStr()); checkDataHelper.CheckData(dbdata, list.ToDictionary(w => w.QiHao.ToString(), w => w.KaiJiangHao), Config.Area, currentLottery); } catch (Exception ex) { log.Error(GetType(), string.Format("【{0}】通过主站点抓取开奖列表时发生错误,错误信息【{1}】", Config.Area + currentLottery, ex.Message)); } return(list); }