public static Nhl_Games_Rtss_Roster ParseHtmlBlob(int rtssReportId, string html) { if (String.IsNullOrWhiteSpace(html) || html.Equals("404")) { return null; } Nhl_Games_Rtss_Roster model = new Nhl_Games_Rtss_Roster(); model.NhlRtssReportModelId = rtssReportId; HtmlDocument htmlDocument = new HtmlDocument(); htmlDocument.LoadHtml(html); HtmlNode documentNode = htmlDocument.DocumentNode; // Special Case // The html for this game doesn't follow the same format as the other games if (null != documentNode.SelectSingleNode(@"./html/head/link[@href='RO010002_files/editdata.mso']")) { return NhlGamesRtssRoster.BruinsRangersSpecialCase(rtssReportId); } // Get the teams HtmlNodeCollection teamNodes = documentNode.SelectNodes(@".//tr/td[contains(@class,'teamHeading + border')]"); string team1 = teamNodes[0].InnerText; string team2 = teamNodes[1].InnerText; // Get the tables that contain a header with '#' HtmlNodeCollection rosterTables = documentNode.SelectNodes(@".//table[tbody/tr/td[text()='#'] or tr/td[text()='#']]"); // Pull out the rows for rosters and scratches. Assume the order of: // 1. visitor roster // 2. home roster // 3. visitor scratches // 4. home scratches // Also, ignore the first rows because they are header fields. HtmlNodeCollection team1RosterNodes = null; HtmlNodeCollection team2RosterNodes = null; if (null != rosterTables && rosterTables.Count >= 2) { team1RosterNodes = rosterTables[0].SelectNodes(@".//tr[position() > 1]"); team2RosterNodes = rosterTables[1].SelectNodes(@".//tr[position() > 1]"); Assert.IsTrue(team1RosterNodes.Count > 10, "team1Roster count"); Assert.IsTrue(team2RosterNodes.Count > 10, "team2Roster count"); } HtmlNodeCollection scratchesNodes = documentNode.SelectNodes(@".//tr[@id='Scratches']/td"); HtmlNodeCollection team1ScratchesNodes = null; HtmlNodeCollection team2ScratchesNodes = null; if (null != scratchesNodes) { team1ScratchesNodes = scratchesNodes[0].SelectNodes(@"./table/tr[position() > 1] | ./table/tbody/tr[position() > 1]"); team2ScratchesNodes = scratchesNodes[1].SelectNodes(@"./table/tr[position() > 1] | ./table/tbody/tr[position() > 1]"); } // Parse the players out of the lists List<Nhl_Games_Rtss_RosterParticipantItem> team1Roster = NhlGamesRtssRoster.ParsePlayers(team1RosterNodes); List<Nhl_Games_Rtss_RosterParticipantItem> team2Roster = NhlGamesRtssRoster.ParsePlayers(team2RosterNodes); List<Nhl_Games_Rtss_RosterParticipantItem> team1Scratches = NhlGamesRtssRoster.ParsePlayers(team1ScratchesNodes); List<Nhl_Games_Rtss_RosterParticipantItem> team2Scratches = NhlGamesRtssRoster.ParsePlayers(team2ScratchesNodes); // Find the head coaches HtmlNodeCollection coachNodes = documentNode.SelectNodes(@".//tr[@id='HeadCoaches']/td/table/tbody/tr | .//tr[@id='HeadCoaches']/td/table/tr"); Nhl_Games_Rtss_RosterParticipantItem coach1 = NhlGamesRtssRoster.ParseCoach(coachNodes[0]); Nhl_Games_Rtss_RosterParticipantItem coach2 = NhlGamesRtssRoster.ParseCoach(coachNodes[1]); // Find the officials HtmlNode officialsTableNode = documentNode.SelectSingleNode(@".//table[tbody/tr/td[contains(text(),'Referee')] or tr/td[contains(text(),'Referee')]]"); HtmlNodeCollection officialsSubTableNodes = officialsTableNode.SelectNodes(@".//table"); HtmlNodeCollection refereesNodes = officialsSubTableNodes[0].SelectNodes(@".//tr"); HtmlNodeCollection linesmenNodes = officialsSubTableNodes[1].SelectNodes(@".//tr"); Nhl_Games_Rtss_RosterParticipantItem referee1 = null; if (refereesNodes != null && refereesNodes.Count >= 1) { referee1 = NhlGamesRtssRoster.ParseReferee(refereesNodes[0]); } Nhl_Games_Rtss_RosterParticipantItem referee2 = null; if (refereesNodes != null && refereesNodes.Count >= 2) { referee2 = NhlGamesRtssRoster.ParseReferee(refereesNodes[1]); } Nhl_Games_Rtss_RosterParticipantItem linesman1 = null; if (linesmenNodes != null && linesmenNodes.Count >= 1) { linesman1 = NhlGamesRtssRoster.ParseLinesman(linesmenNodes[0]); } Nhl_Games_Rtss_RosterParticipantItem linesman2 = null; if (linesmenNodes != null && linesmenNodes.Count >= 2) { linesman2 = NhlGamesRtssRoster.ParseLinesman(linesmenNodes[1]); } // Check for standby officials HtmlNodeCollection standbyOfficialsNodes1 = officialsSubTableNodes[2].SelectNodes(@".//tr"); HtmlNodeCollection standbyOfficialsNodes2 = officialsSubTableNodes[3].SelectNodes(@".//tr"); if (null != standbyOfficialsNodes1 || null != standbyOfficialsNodes2) { Console.WriteLine("Encountered potential standby officials in RTSS report {0}", rtssReportId); } // Fill out the model model.VisitorHeadCoach = new List<Nhl_Games_Rtss_RosterParticipantItem> { coach1 }; model.HomeHeadCoach = new List<Nhl_Games_Rtss_RosterParticipantItem> { coach2 }; model.VisitorRoster = team1Roster; model.HomeRoster = team2Roster; model.VisitorScratches = team1Scratches; model.HomeScratches = team2Scratches; model.Linesman = new List<Nhl_Games_Rtss_RosterParticipantItem> { linesman1, linesman2 }; model.Referees = new List<Nhl_Games_Rtss_RosterParticipantItem> { referee1, referee2 }; return model; }
private static Nhl_Games_Rtss_Roster BruinsRangersSpecialCase(int rtssReportId) { Nhl_Games_Rtss_Roster model = new Nhl_Games_Rtss_Roster(); model.NhlRtssReportModelId = rtssReportId; model.VisitorRoster = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 12, Position = "R", Name = "CHUCK KOBASEW", Designation = Designation.AssistantCaptain }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 16, Position = "L", Name = "MARCO STRUM", Designation = Designation.AssistantCaptain }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 17, Position = "L", Name = "MILAN LUCIC" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 26, Position = "R", Name = "BLAKE WHEELER" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 33, Position = "D", Name = "ZDENO CHARA", Designation = Designation.Captain }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 42, Position = "C", Name = "TRENT WHITFIELD" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 48, Position = "D", Name = "MATT HUNWICK" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 52, Position = "C", Name = "ZACH HAMILL" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 54, Position = "D", Name = "ADAM MCQUAID" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 55, Position = "D", Name = "JOHNNY BOYCHUK" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 60, Position = "C", Name = "VLADIMIR SOBOTKA" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 61, Position = "R", Name = "BYRON BITZ" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 62, Position = "D", Name = "JEFFREY PENNER" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 63, Position = "C", Name = "BRAD MARCHAND" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 65, Position = "D", Name = "ANDREW BODNARCHUK" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 68, Position = "R", Name = "MIKKO LEHTONEN" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 72, Position = "C", Name = "JAMIE ARNIEL" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 74, Position = "C", Name = "MAX SAUVE" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 32, Position = "G", Name = "DANY SABOURIN" }); model.VisitorRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 40, Position = "G", Name = "TUUKKA RASK" }); model.VisitorRoster.ToList().ForEach(m => m.ParticipantType = ParticipantType.Player); model.HomeRoster = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 5, Position = "D", Name = "DAN GIRARDI" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 12, Position = "R", Name = "ALES KOTALIK" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 18, Position = "D", Name = "MARC STAAL" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 21, Position = "L", Name = "CHRISTOPHER HIGGINS" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 22, Position = "C", Name = "BRIAN BOYLE" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 23, Position = "C", Name = "CHRIS DRURY", Designation = Designation.Captain }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 24, Position = "R", Name = "RYAN CALLAHAN" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 25, Position = "D", Name = "ALEXEI SEMENOV" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 32, Position = "D", Name = "MICHAEL SAUER" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 36, Position = "L", Name = "DANE BYERS" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 38, Position = "R", Name = "PIERRE PARENTEAU" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 42, Position = "C", Name = "ARTEM ANISIMOV" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 43, Position = "D", Name = "MICHAEL DEL ZOTTO" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 59, Position = "C", Name = "EVGENY GRACHEV" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 81, Position = "R", Name = "ENVER LISIN" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 85, Position = "L", Name = "MATT MACCARONE" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 87, Position = "L", Name = "DONALD BRASHEAR" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 97, Position = "D", Name = "MATT GILROY" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 31, Position = "G", Name = "MATT ZABA" }); model.HomeRoster.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 40, Position = "G", Name = "STEPHEN VALIQUETTE" }); model.HomeRoster.ToList().ForEach(m => m.ParticipantType = ParticipantType.Player); // Since this is a preseason game, don't bother filling in the scratches. The data is available here http://www.nhl.com/scores/htmlreports/20092010/RO010002.HTM model.VisitorScratches = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.HomeScratches = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.VisitorHeadCoach = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.VisitorHeadCoach.Add(new Nhl_Games_Rtss_RosterParticipantItem { Name = "CLAUDE JULIEN", Designation = Designation.HeadCoach, ParticipantType = ParticipantType.Coach }); model.HomeHeadCoach = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.HomeHeadCoach.Add(new Nhl_Games_Rtss_RosterParticipantItem { Name = "JOHN TORTORELLA", Designation = Designation.HeadCoach, ParticipantType = ParticipantType.Coach }); model.Referees = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.Referees.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 8, Name = "Dave Jackson", Designation = Designation.Referee, ParticipantType = ParticipantType.Official }); model.Referees.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 41, Name = "Chris Ciamaga", Designation = Designation.Referee, ParticipantType = ParticipantType.Official }); model.Linesman = new List<Nhl_Games_Rtss_RosterParticipantItem>(); model.Referees.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 84, Name = "Tony Sericolo", Designation = Designation.Linesman, ParticipantType = ParticipantType.Official }); model.Referees.Add(new Nhl_Games_Rtss_RosterParticipantItem { Number = 77, Name = "Tim Nowak", Designation = Designation.Linesman, ParticipantType = ParticipantType.Official }); return model; }