当前位置: 首页>>代码示例>>C#>>正文


C# HtmlDocument.FirstOfDescendantsWithClass方法代码示例

本文整理汇总了C#中HtmlAgilityPack.HtmlDocument.FirstOfDescendantsWithClass方法的典型用法代码示例。如果您正苦于以下问题:C# HtmlDocument.FirstOfDescendantsWithClass方法的具体用法?C# HtmlDocument.FirstOfDescendantsWithClass怎么用?C# HtmlDocument.FirstOfDescendantsWithClass使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在HtmlAgilityPack.HtmlDocument的用法示例。


在下文中一共展示了HtmlDocument.FirstOfDescendantsWithClass方法的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetMessageDetails

        public async Task<MalMessageModel> GetMessageDetails(MalMessageModel msg)
        {
            try
            {
                var client = await MalHttpContextProvider.GetHttpContextAsync();
                var response = await client.GetAsync($"/mymessages.php?go=read&id={msg.Id}");
                var raw = await response.Content.ReadAsStringAsync();

                var doc = new HtmlDocument();
                doc.LoadHtml(raw);

                var msgNode = doc.FirstOfDescendantsWithClass("td", "dialog-text");
                var msgContent = msgNode.ChildNodes.Skip(3)
                    .Where(node => node.NodeType == HtmlNodeType.Text)
                    .Aggregate("", (current, textNode) => current + textNode.InnerText);

                msg.Content = WebUtility.HtmlDecode(msgContent.Trim());
                var ids =
                    doc.FirstOfDescendantsWithClass("input", "inputButton btn-middle flat").Attributes["onclick"].Value
                        .Split('=');
                msg.ThreadId = ids[4].Substring(0, ids[3].IndexOf('&'));
                msg.ReplyId = ids[3].Substring(0, ids[3].IndexOf('&'));
                return msg;
            }
            catch (WebException)
            {
                MalHttpContextProvider.ErrorMessage("Messages");
            }

            return new MalMessageModel();
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:31,代码来源:MalMessageDetailsQuery.cs

示例2: GetFirstSentMessageId

        /// <summary>
        ///     When we send new message we don't really know its id so we have to pull it.
        ///     Once we have that we will be able to pull thread id.
        /// </summary>
        public async Task<string> GetFirstSentMessageId()
        {
            try
            {
                var client = await MalHttpContextProvider.GetHttpContextAsync();
                var res = await client.GetAsync("/mymessages.php?go=sent");
                var body = await res.Content.ReadAsStringAsync();

                try
                {
                    var doc = new HtmlDocument();
                    doc.LoadHtml(body);
                    //?go=read&id=8473147&f=1
                    var id =
                        doc.FirstOfDescendantsWithClass("div", "message read spot2 clearfix")
                            .Descendants("a")
                            .Skip(1)
                            .First()
                            .Attributes["href"].Value.Split('=')[2];
                    return id.Substring(0, id.Length - 2);
                }
                catch (Exception)
                {
                    return "0";
                }
            }
            catch (WebException)
            {
                MalHttpContextProvider.ErrorMessage("Messages");
            }
            return "0";
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:36,代码来源:MalMessagesQuery.cs

示例3: GetMangaCharacters

        public async Task<List<AnimeCharacter>> GetMangaCharacters(bool force) //html is malformed
        {
            if (_animeMode)
                throw new InvalidOperationException("You fed constructor with anime, remember?");

            var output = force
                ? new List<AnimeCharacter>()
                : await DataCache.RetrieveData<List<AnimeCharacter>>($"staff_{_animeId}", "MangaDetails", 7) ??
                  new List<AnimeCharacter>();

            var raw = await GetRequestResponse(false);
            if (string.IsNullOrEmpty(raw))
                return null;

            var doc = new HtmlDocument();
            doc.LoadHtml(raw);
            try
            {
                var mainContainer = doc.FirstOfDescendantsWithClass("div", "js-scrollfix-bottom-rel");
                var tables = mainContainer.ChildNodes.Where(node => node.Name == "table").ToList();

                foreach (var table in tables)
                {
                    try
                    {
                        var current = new AnimeCharacter();

                        var imgs = table.Descendants("img").ToList();
                        var infos = table.Descendants("td").ToList();

                        //character
                        var img = imgs[0].Attributes["data-src"].Value;
                        if (!img.Contains("questionmark"))
                        {
                            img = img.Replace("/r/46x64", "");
                            current.ImgUrl = img.Substring(0, img.IndexOf('?'));
                        }

                        current.FromAnime = _animeMode;
                        current.ShowId = _animeId.ToString();
                        current.Name = WebUtility.HtmlDecode(imgs[0].Attributes["alt"].Value.Replace(",", ""));
                        current.Id = infos[0].ChildNodes[1].ChildNodes[0].Attributes["href"].Value.Split('/')[2];
                        current.Notes = ""; //malformed html here TODO: Check if fixed 
                        //table.Descendants("small").First().InnerText;
                        output.Add(current);
                    }
                    catch (Exception)
                    {
                        //
                    }

                }
            }
            catch (Exception)
            {
                //html strikes again
            }
            return output;
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:59,代码来源:AnimeCharactersStaffQuery.cs

示例4: GetVideos

        public async Task<List<AnimeVideoData>> GetVideos(bool force)
        {

            var output = force
                ? new List<AnimeVideoData>()
                : await DataCache.RetrieveData<List<AnimeVideoData>>($"videos_{_id}", "AnimeDetails", 7) ??
                  new List<AnimeVideoData>();

            if (output.Any())
                return output;

            var raw = await GetRequestResponse(false);
            if (string.IsNullOrEmpty(raw))
                return output;

            var doc = new HtmlDocument();
            doc.LoadHtml(raw);

            try
            {
                foreach (
                    var video in
                    doc.FirstOfDescendantsWithClass("div", "video-block promotional-video mt16")
                        .WhereOfDescendantsWithClass("div", "video-list-outer po-r pv"))
                {
                    try
                    {
                        var current = new AnimeVideoData();
                        var img = video.Descendants("img").First();
                        current.Thumb = img.Attributes["data-src"].Value;
                        if (current.Thumb.Contains("banned"))
                            continue;
                        var href = video.Descendants("a").First().Attributes["href"].Value;
                        var pos = href.IndexOf('?');
                        href = href.Substring(0, pos);
                        current.YtLink = $"https://www.youtube.com/watch?v={href.Split('/').Last()}";

                        current.Name = WebUtility.HtmlDecode(img.Attributes["data-title"].Value);

                        output.Add(current);
                    }
                    catch (Exception)
                    {
                        //html
                    }

                }
            }
            catch (Exception)
            {
                //no videos
            }

            DataCache.SaveData(output, $"videos_{_id}", "AnimeDetails");

            return output;

        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:58,代码来源:AnimeVideosQuery.cs

示例5: GetMessagesInThread

        public async Task<List<MalMessageModel>> GetMessagesInThread(MalMessageModel msg)
        {
            try
            {
                var client = await MalHttpContextProvider.GetHttpContextAsync();
                var response = await client.GetAsync($"/mymessages.php?go=read&id={msg.Id}&threadid={msg.ThreadId}");
                var raw = await response.Content.ReadAsStringAsync();

                var doc = new HtmlDocument();
                doc.LoadHtml(raw);

                var output = new List<MalMessageModel>();

                foreach (
                    var msgHistoryNode in
                        doc.FirstOfDescendantsWithClass("table", "pmessage-message-history").Descendants("tr"))
                {
                    var current = new MalMessageModel();
                    var tds = msgHistoryNode.Descendants("td").ToList();
                    current.Content = WebUtility.HtmlDecode(tds[2].InnerText.Trim());
                    if (string.IsNullOrEmpty(current.Content))
                        continue;


                    current.Subject = msg.Subject;
                    current.Date = tds[0].InnerText.Trim();
                    current.Sender = tds[1].InnerText.Trim();
                    output.Add(current);
                }


                return output;
            }
            catch (Exception)
            {
                MalHttpContextProvider.ErrorMessage("Messages");
            }

            return new List<MalMessageModel>();

        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:41,代码来源:MalMessageDetailsQuery.cs

示例6: GetArticleHtml

        public async Task<string> GetArticleHtml()
        {
            var possibleData = await DataCache.RetrieveArticleContentData(_title, _type);
            if (possibleData != null)
                return possibleData;
            var raw = await GetRequestResponse();
            if (string.IsNullOrEmpty(raw))
                return null;
            var doc = new HtmlDocument();
            doc.LoadHtml(raw);
            string htmlData;
            try
            {
                htmlData = doc.FirstOfDescendantsWithClass("div", "news-container").OuterHtml;
                DataCache.SaveArticleContentData(_title, htmlData, _type);
            }
            catch (Exception)
            {
                htmlData = "Something went wrong";
            }

            return htmlData;
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:23,代码来源:MalArticleQuery.cs

示例7: GetSeasonalAnime

        public async Task<List<SeasonalAnimeData>> GetSeasonalAnime(bool force = false)
        {
            var output = force || DataCache.SeasonalUrls?.Count == 0 //either force or urls are empty after update
                ? new List<SeasonalAnimeData>()
                : await DataCache.RetrieveSeasonalData(_overriden ? _season.Name : "") ?? new List<SeasonalAnimeData>();
            //current season without suffix
            if (output.Count != 0) return output;
            var raw = await GetRequestResponse();
            if (string.IsNullOrEmpty(raw))
                return output;


            //Get season data - we are getting this only from current season
            try
            {
                var doc = new HtmlDocument();
                doc.LoadHtml(raw);
                var mainNode =
                    doc.DocumentNode.Descendants("div")
                        .First(
                            node =>
                                node.Attributes.Contains("class") &&
                                node.Attributes["class"].Value ==
                                HtmlClassMgr.ClassDefs["#Seasonal:mainNode:class"]);
                if (!_overriden)
                {
                    var seasonInfoNodes = doc.DocumentNode.Descendants("div").First(
                        node =>
                            node.Attributes.Contains("class") &&
                            node.Attributes["class"].Value ==
                            HtmlClassMgr.ClassDefs["#Seasonal:seasonInfo:class"]).Descendants("li").ToList();
                    var seasonData = new Dictionary<string, string>();
                    for (var j = 1; j <= 4; j++)
                    {
                        try
                        {
                            seasonData.Add(seasonInfoNodes[j].Descendants("a").First().InnerText.Trim(),
                                seasonInfoNodes[j].Descendants("a").First().Attributes["href"].Value);

                            if (seasonInfoNodes[j].Descendants("a").First().Attributes["class"].Value ==
                                HtmlClassMgr.ClassDefs["#Seasonal:seasonInfoCurrent:class"])
                                seasonData.Add("current", j.ToString());
                        }
                        catch (Exception)
                        {
                            //ignored
                        }
                    }
                    DataCache.SaveSeasonalUrls(seasonData);
                }

                //Get anime data
                var nodes = mainNode.ChildNodes.Where(node => node.Name == "div").Take(Settings.SeasonalToPull);
                try
                {
                    //add movies if any
                    nodes =
                        nodes.Concat(
                            doc.FirstOfDescendantsWithClass("div",
                                    "seasonal-anime-list js-seasonal-anime-list js-seasonal-anime-list-key-3 clearfix")
                                .ChildNodes.Where(node => node.Name == "div"));
                }
                catch (Exception e)
                {
                    //no movies or corrupt html
                }

                var i = 0;
                foreach (var htmlNode in nodes)
                {
                    try
                    {
                        var model = ParseFromHtml(htmlNode, i);
                        if(model == null)
                            continue;
                        output.Add(model);
                        i++;
                    }
                    catch (Exception e)
                    {

                    }
                }
            }
            catch (Exception e)
            {
                //sumthing
            }


            DataCache.SaveSeasonalData(output, _overriden ? _season.Name : "");

            //We are done.
            return output;
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:95,代码来源:AnimeSeasonalQuery.cs

示例8: GetCharStaffData

        public async Task<AnimeStaffData> GetCharStaffData(bool force = false)
        {
            if (!_animeMode)
                throw new InvalidOperationException("Umm you said it's going to be manga...");
            var output = force
                ? new AnimeStaffData()
                : await DataCache.RetrieveData<AnimeStaffData>($"staff_{_animeId}", "AnimeDetails", 7) ??
                  new AnimeStaffData();
            if (output.AnimeCharacterPairs.Count > 0 || output.AnimeStaff.Count > 0) return output;

            var raw = await GetRequestResponse(false);
            if (string.IsNullOrEmpty(raw))
                return null;

            var doc = new HtmlDocument();
            doc.LoadHtml(raw);

            try
            {
                var mainContainer = doc.FirstOfDescendantsWithClass("div", "js-scrollfix-bottom-rel");
                var tables = mainContainer.ChildNodes.Where(node => node.Name == "table").ToList();
                int i = 0;
                foreach (var table in tables.Take(tables.Count - 1))
                {
                    try
                    {
                        var current = new AnimeCharacterStaffModel();

                        var imgs = table.Descendants("img").ToList();
                        var infos = table.Descendants("td").ToList(); //2nd is character 4th is person

                        //character
                        var img = imgs[0].Attributes["data-src"].Value;
                        if (!img.Contains("questionmark"))
                        {
                            img = img.Replace("/r/46x64", "");
                            current.AnimeCharacter.ImgUrl = img.Substring(0, img.IndexOf('?'));
                        }

                        current.AnimeCharacter.FromAnime = _animeMode;
                        current.AnimeCharacter.ShowId = _animeId.ToString();
                        current.AnimeCharacter.Name =
                            WebUtility.HtmlDecode(imgs[0].Attributes["alt"].Value.Replace(",", ""));
                        current.AnimeCharacter.Id = infos[1].ChildNodes[1].Attributes["href"].Value.Split('/')[2];
                        current.AnimeCharacter.Notes = infos[1].ChildNodes[3].InnerText;

                        //voiceactor
                        try
                        {
                            img = imgs[1].Attributes["data-src"].Value;
                            if (!img.Contains("questionmark"))
                            {
                                img = img.Replace("/r/46x64", "");
                                current.AnimeStaffPerson.ImgUrl = img.Substring(0, img.IndexOf('?'));
                            }
                            current.AnimeStaffPerson.Name = WebUtility.HtmlDecode(imgs[1].Attributes["alt"].Value.Replace(",", ""));
                            current.AnimeStaffPerson.Id = infos[3].ChildNodes[1].Attributes["href"].Value.Split('/')[2];
                            current.AnimeStaffPerson.Notes = infos[3].ChildNodes[4].InnerText;
                        }
                        catch (Exception)
                        {
                            //no voice actor
                            current.AnimeStaffPerson.Name = "Unknown";
                            current.AnimeStaffPerson.IsUnknown = true;
                        }


                        output.AnimeCharacterPairs.Add(current);
                        if (i++ > 30)
                            break;
                    }
                    catch (Exception)
                    {
                        //oddities
                    }

                }
                i = 0;
                foreach (var staffRow in tables.Last().Descendants("tr"))
                {
                    try
                    {
                        var current = new AnimeStaffPerson();
                        var imgs = staffRow.Descendants("img").ToList();
                        var info = staffRow.Descendants("td").Last(); //we want last

                        var img = imgs[0].Attributes["data-src"].Value;
                        if (!img.Contains("questionmark"))
                        {
                            img = img.Replace("/r/46x64", "");
                            current.ImgUrl = img.Substring(0, img.IndexOf('?'));
                        }
                        current.Name = WebUtility.HtmlDecode(imgs[0].Attributes["alt"].Value.Replace(",", ""));
                        current.Id = info.ChildNodes[0].Attributes["href"].Value.Split('/')[2];
                        current.Notes = info.ChildNodes[3].InnerText;

                        output.AnimeStaff.Add(current);
                        if (i++ > 30)
                            break;
                    }
//.........这里部分代码省略.........
开发者ID:Mordonus,项目名称:MALClient,代码行数:101,代码来源:AnimeCharactersStaffQuery.cs

示例9: GetDetails

        public async Task<AnimeScrappedDetails> GetDetails(bool force)
        {
            var possibleData = force ? null :
                await DataCache.RetrieveData<AnimeScrappedDetails>(_id.ToString(), "anime_details_scrapped", 14);
            if (possibleData != null)
                return possibleData;

            var output = new AnimeScrappedDetails();
            var raw = await GetRequestResponse();
            if (string.IsNullOrEmpty(raw))
                return null;
            var doc = new HtmlDocument();
            doc.LoadHtml(raw);

            output.Id = _id;

            bool recording = false;
            string currentString = "";
            int currentStage = 0;
            try
            {
                foreach (var child in doc.FirstOfDescendantsWithClass("div", "js-scrollfix-bottom").ChildNodes)
                {

                    if (!recording)
                    {
                        if (child.Attributes.Contains("class") &&
                            child.Attributes["class"].Value.Contains("js-sns-icon-container"))
                            recording = true;
                        continue;
                    }
                    if (child.Name == "div" && child.Attributes.Contains("class") && child.Attributes["class"].Value.Contains("mauto"))
                        break;

                    if (child.Name == "h2")
                    {
                        currentStage++;
                        continue;
                    }
                    if (child.Name == "div")
                    {
                        currentString = Regex.Replace(WebUtility.HtmlDecode(child.InnerText.Replace('\n', ' ').Trim()), @"[ ]{2,}", " ");
                        switch (currentStage)
                        {
                            case 1:
                                output.AlternativeTitles.Add(currentString);
                                break;
                            case 2:
                                output.Information.Add(currentString);
                                break;
                            case 3:
                                output.Statistics.Add(currentString);
                                break;
                        }
                    }


                }

                if (_anime)
                {
                    foreach (var row in doc.FirstOfDescendantsWithClass("div", "theme-songs js-theme-songs ending").Descendants("span"))
                    {
                        output.Endings.Add(WebUtility.HtmlDecode(row.InnerText));
                    }
                    foreach (var row in doc.FirstOfDescendantsWithClass("div", "theme-songs js-theme-songs opnening").Descendants("span"))
                    {
                        output.Openings.Add(WebUtility.HtmlDecode(row.InnerText));
                    }
                }
            }
            catch (Exception)
            {
                //hatemeł
            }
            
            DataCache.SaveData(output,_id.ToString(), "anime_details_scrapped");
            return output;
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:79,代码来源:AnimeDetailsMalQuery.cs

示例10: GetComments

        public async Task<List<MalComment>> GetComments()
        {
            var raw = await (await MalHttpContextProvider.GetHttpContextAsync()).GetAsync($"/profile/{_userName}");
            var doc = new HtmlDocument();
            doc.LoadHtml(await raw.Content.ReadAsStringAsync());
            var output = new List<MalComment>();
            try
            {
                var commentBox = doc.FirstOfDescendantsWithClass("div", "user-comments mt24 pt24");
                foreach (var comment in commentBox.WhereOfDescendantsWithClass("div", "comment clearfix"))
                {
                    var curr = new MalComment();
                    curr.User.ImgUrl = comment.Descendants("img").First().Attributes["src"].Value;
                    var textBlock = comment.Descendants("div").First();
                    var header = textBlock.Descendants("div").First();
                    curr.User.Name = header.ChildNodes[1].InnerText;
                    curr.Date = header.ChildNodes[3].InnerText;
                    curr.Content = WebUtility.HtmlDecode(textBlock.Descendants("div").Skip(1).First().InnerText.Trim());
                    var postActionNodes = comment.WhereOfDescendantsWithClass("a", "ml8");
                    var convNode = postActionNodes.FirstOrDefault(node => node.InnerText.Trim() == "Conversation");
                    if (convNode != null)
                    {
                        curr.ComToCom = WebUtility.HtmlDecode(convNode.Attributes["href"].Value.Split('?').Last());
                    }
                    var deleteNode = postActionNodes.FirstOrDefault(node => node.InnerText.Trim() == "Delete");
                    if(deleteNode != null)
                    {
                        curr.CanDelete = true;
                        curr.Id =
                            deleteNode.Attributes["onclick"].Value.Split(new char[] { '(', ')' },
                                StringSplitOptions.RemoveEmptyEntries).Last();
                    }
                    output.Add(curr);
                }
            }
            catch (Exception)
            {
                //no comments
            }

            await Task.Run( async () =>
            {
                var data = await DataCache.RetrieveProfileData(_userName);
                if (data != null)
                {
                    data.Comments = output;
                }
                DataCache.SaveProfileData(_userName, data);
            });

            return output;
        }
开发者ID:Mordonus,项目名称:MALClient,代码行数:52,代码来源:ProfileQuery.cs

示例11: GetProfileData


//.........这里部分代码省略.........
                foreach (
                    var favPersonNode in
                        doc.DocumentNode.Descendants("ul")
                            .First(
                                node =>
                                    node.Attributes.Contains("class") &&
                                    node.Attributes["class"].Value ==
                                    HtmlClassMgr.ClassDefs["#Profile:favPeopleNode:class"])
                            .Descendants("li"))
                {
                    var curr = new AnimeStaffPerson();
                    var aElems = favPersonNode.Descendants("a");
                    var styleString = aElems.First().Attributes["style"].Value.Substring(22);
                    curr.ImgUrl = styleString.Replace("/r/80x120", "");
                    curr.ImgUrl = curr.ImgUrl.Substring(0, curr.ImgUrl.IndexOf('?'));

                    curr.Name = aElems.Skip(1).First().InnerText.Trim();
                    curr.Id = aElems.Skip(1).First().Attributes["href"].Value.Substring(9).Split('/')[2];

                    current.FavouritePeople.Add(curr);
                }
            }
            catch (Exception)
            {
                //no favs
            }

            #endregion

            #region Stats
            if (!updateFavsOnly)
                try
                {
                    var animeStats = doc.FirstOfDescendantsWithClass("div", "stats anime");
                    var generalStats = animeStats.Descendants("div").First().Descendants("div");
                    current.AnimeDays = float.Parse(generalStats.First().InnerText.Substring(5).Trim());
                    current.AnimeMean = float.Parse(generalStats.Last().InnerText.Substring(11).Trim());
                    var i = 0;

                    #region AnimeStats

                    foreach (
                        var htmlNode in
                            animeStats.FirstOfDescendantsWithClass("ul", "stats-status fl-l").Descendants("li"))
                    {
                        switch (i)
                        {
                            case 0:
                                current.AnimeWatching =
                                    int.Parse(htmlNode.Descendants("span").First().InnerText.Trim().Replace(",", ""));
                                break;

                            case 1:
                                current.AnimeCompleted =
                                    int.Parse(htmlNode.Descendants("span").First().InnerText.Trim().Replace(",", ""));
                                break;
                            case 2:
                                current.AnimeOnHold =
                                    int.Parse(htmlNode.Descendants("span").First().InnerText.Trim().Replace(",", ""));
                                break;
                            case 3:
                                current.AnimeDropped =
                                    int.Parse(htmlNode.Descendants("span").First().InnerText.Trim().Replace(",", ""));
                                break;
                            case 4:
                                current.AnimePlanned =
开发者ID:Mordonus,项目名称:MALClient,代码行数:67,代码来源:ProfileQuery.cs

示例12: GetTopicPosts

        public async Task<ForumBoardContent> GetTopicPosts(int? lastPage,bool force = false)
        {
            if(!force)
                try
                {
                    if (_animeId == 0)
                    {
                        if (_boardCache.ContainsKey(_board) && _boardCache[_board].ContainsKey(_page))
                            return _boardCache[_board][_page];
                    }
                    else
                    {
                        if (_animeBoardCache.ContainsKey(_animeId) && _animeBoardCache[_animeId].ContainsKey(_page))
                            return _animeBoardCache[_animeId][_page];
                    }
                }
                catch (Exception e)
                {
                    //
                }
            else //clear all pages
            {
                if (_animeId == 0)
                {
                    if(_boardCache.ContainsKey(_board))
                        _boardCache[_board] = new Dictionary<int, ForumBoardContent>();
                }
                else
                {
                    if (_animeBoardCache.ContainsKey(_animeId))
                        _animeBoardCache[_animeId] = new Dictionary<int, ForumBoardContent>();
                }
            }



            var output = new ForumBoardContent();
            var raw = await GetRequestResponse();
            if (string.IsNullOrEmpty(raw))
                return new ForumBoardContent();
            var doc = new HtmlDocument();
            doc.LoadHtml(raw);

            try
            {
                try
                {
                    output.Pages = lastPage ??
                                   int.Parse(
                                       doc.FirstOfDescendantsWithClass("span", "di-ib")
                                           .Descendants("a")
                                           .Last()
                                           .Attributes["href"]
                                           .Value.Split('=').Last())/50;
                }
                catch (Exception)
                {
                    output.Pages = 0;
                }


                var topicContainer =
                doc.DocumentNode.Descendants("table")
                    .First(node => node.Attributes.Contains("id") && node.Attributes["id"].Value == "forumTopics");

                foreach (var topicRow in topicContainer.Descendants("tr").Skip(1)) //skip forum table header
                {
                    try
                    {
                        output.ForumTopicEntries.Add(ParseHtmlToTopic(topicRow));
                    }
                    catch (Exception)
                    {
                        //hatml
                    }

                }
            }
            catch (Exception)
            {
                //
            }
            

            if (_animeId == 0)
            {
                if (!_boardCache.ContainsKey(_board))
                    _boardCache[_board] = new Dictionary<int, ForumBoardContent>();
                if (!_boardCache[_board].ContainsKey(_page))
                    _boardCache[_board].Add(_page, output);
                else
                    _boardCache[_board][_page] = output;
            }
            else
            {
                if (!_animeBoardCache.ContainsKey(_animeId))
                    _animeBoardCache[_animeId] = new Dictionary<int, ForumBoardContent>();
                if (!_animeBoardCache[_animeId].ContainsKey(_page))
                    _animeBoardCache[_animeId].Add(_page, output);
                else
//.........这里部分代码省略.........
开发者ID:Mordonus,项目名称:MALClient,代码行数:101,代码来源:ForumBoardTopicsQuery.cs


注:本文中的HtmlAgilityPack.HtmlDocument.FirstOfDescendantsWithClass方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。