本文整理汇总了C#中HtmlAgilityPack.HtmlNode.Elements方法的典型用法代码示例。如果您正苦于以下问题:C# HtmlNode.Elements方法的具体用法?C# HtmlNode.Elements怎么用?C# HtmlNode.Elements使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类HtmlAgilityPack.HtmlNode
的用法示例。
在下文中一共展示了HtmlNode.Elements方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ParseLeagueTableRow
private ClubSeasonPerformance ParseLeagueTableRow(HtmlNode tableRow)
{
var cells = tableRow.Elements("td").ToArray();
var name = cells[1].InnerText;
return new ClubSeasonPerformance
{
Club = Clubs.GetClubFromName(name),
HomePlayed = byte.Parse(cells[2].InnerText),
HomeWon = byte.Parse(cells[3].InnerText),
HomeDrawn = byte.Parse(cells[4].InnerText),
HomeLost = byte.Parse(cells[5].InnerText),
HomeGoalsFor = byte.Parse(cells[6].InnerText),
HomeGoalsAgainst = byte.Parse(cells[7].InnerText),
AwayPlayed = byte.Parse(cells[10].InnerText),
AwayWon = byte.Parse(cells[11].InnerText),
AwayDrawn = byte.Parse(cells[12].InnerText),
AwayLost = byte.Parse(cells[13].InnerText),
AwayGoalsFor = byte.Parse(cells[14].InnerText),
AwayGoalsAgainst = byte.Parse(cells[15].InnerText)
};
}
示例2: GetLatestVideos
void GetLatestVideos(ref List<VideoInfo> result, HtmlNode li_container)
{
foreach (var li in li_container.Elements("li"))
{
if (li.GetAttributeValue("class", "").Contains("more_reiter"))
{
HasNextPage = true;
nextPageUrl = "http://www.heise.de/video/" + li.Element("a").GetAttributeValue("href", "") + "&hajax=1";
}
else
{
SerializableDictionary<string, string> tags = null;
if (li.Element("ul") != null)
{
tags = new SerializableDictionary<string, string>();
foreach (var tag_li in li.Element("ul").Elements("li"))
{
tags.Add(tag_li.Element("a").InnerText, "http://www.heise.de" + tag_li.Element("a").GetAttributeValue("href", ""));
}
}
var a = li.Descendants("h3").First().Element("a");
result.Add(new VideoInfo()
{
Title = a.InnerText,
VideoUrl = "http://www.heise.de" + a.GetAttributeValue("href", ""),
Thumb = "http://www.heise.de" + li.Descendants("img").First().GetAttributeValue("src", ""),
Description = li.Descendants("p").First().FirstChild.InnerText.Trim(),
Other = tags
});
}
}
}
示例3: CreateSubtitleFromLink
private SubsceneSubtitle CreateSubtitleFromLink(HtmlNode anchor, string link)
{
const string goodRatingClassName = "r100";
const string neutralRatingClassName = "r0";
var spans = anchor.Elements("span").ToArray();
var firstSpan = spans.First();
var ratingClass = firstSpan.Attributes["class"].Value;
var ratingType = ratingClass.Contains(goodRatingClassName) ? 1 : ratingClass.Contains(neutralRatingClassName) ? 0 : -1;
var language = firstSpan.InnerText.Trim();
var lastSpan = spans.Last();
var releaseName = RemoveComments(lastSpan?.InnerText.Trim());
var relaseIdentity = _releaseParser.ParseEpisodeInfo(releaseName);
var subtitle = new SubsceneSubtitle
{
SubtitleLink = link,
LanguageName = language,
ReleaseName = releaseName,
SeriesName = relaseIdentity.SeriesName,
Season = relaseIdentity.Season,
Episode = relaseIdentity.Episode,
EndEpisode = relaseIdentity.EndEpisode,
ReleaseGroup = relaseIdentity.ReleaseGroup,
RatingType = ratingType
};
return subtitle;
}
示例4: SearchResult
public SearchResult(HtmlNode tr)
{
var img = tr.Elements("th").First().Descendants("img").SingleOrDefault();
if (img != null)
ISBN = imageUrlParser.Match(img.GetAttributeValue("src", "")).Groups[1].Value;
var details = tr.Elements("td").Last().Element("span");
//This is "Last, First"
Author = details.FirstChild.CleanText().TrimEnd('.');
var authorTitle = details.Element("b").CleanText().Split('/');
Title = authorTitle[0].Trim();
//This is "First Last"
//Author = authorTitle[0].Trim();
var publisherNode = details.Element("b").NextSibling;
while (String.IsNullOrWhiteSpace(publisherNode.InnerText))
publisherNode = publisherNode.NextSibling;
Year = GetYear(publisherNode.InnerText);
var script = tr.Descendants("script").First();
sessionDetailsUrl = detailsUrlFinder.Match(script.InnerText).Groups[1].Value;
}
示例5: ClearNodes
private static HtmlNode ClearNodes(HtmlNode JobOfferElement)
{
//var trsToRemove = JobOfferElement.Elements("tr").ToList();
//JobOfferElement.RemoveChild(trsToRemove[0]);
//JobOfferElement.RemoveChild(trsToRemove[1]);
//JobOfferElement.RemoveChild(trsToRemove[2]);
JobOfferElement = RemoveDescendants(JobOfferElement, new string[] { "a", "img", "script", "style" });
JobOfferElement.RemoveChild(JobOfferElement.Element("tr"));
var trS = JobOfferElement.Elements("tr").ToList();
bool removeNext = false;
foreach (var item in trS)
{
if (removeNext == false)
{
if (item.Descendants().Where(
d => (d.Attributes.Contains("class") &&
d.Attributes["class"].Value.Contains("button_new"))
).Count() > 0)
{
removeNext = true;
}
}
if (removeNext == true)
{
JobOfferElement.RemoveChild(item);
}
}
return JobOfferElement;
}
示例6: ParseSearchedSongTable
internal List<SongModel> ParseSearchedSongTable(HtmlNode table)
{
string temp = table.InnerHtml;
foreach(Match m in Regex.Matches(temp, @"(<tbody\s)[\s\S]+?(/tbody>)"))
{
StringBuilder sb = new StringBuilder();
sb.Append("</tbody>");
sb.Append(m.Value);
sb.Append("<tbody>");
temp = temp.Replace(m.Value, sb.ToString());
}
table.InnerHtml = temp;
List<SongModel> res = new List<SongModel>();
foreach(var node in table.Elements("tbody"))
{
if (node.GetAttributeValue("class", "").Contains("same_song_group"))
res.AddRange(node.Elements("tr").Select((tr) =>
{
var song = ParseSearchedSong(tr);
song.DuplicateOf = res[res.Count - 1];
return song;
})); // 不全部返回的话会造成歌曲数目不够,PageItem加载时会产生Exception
else
res.AddRange(node.Elements("tr").Select((tr) => ParseSearchedSong(tr)));
};
return res;
}
示例7: ParseSearchedSong
internal SongModel ParseSearchedSong(HtmlNode tr)
{
//System.Diagnostics.Debugger.Break();
var tds = tr.Elements("td").ToList();
var checkbox = tds[0].Descendant("input");
SongModel song = SongModel.GetNew(uint.Parse(checkbox.GetAttributeValue("value", "0")));
song.Available = checkbox.GetAttributeValue("checked", "") == "checked";
var links = tds[1].SelectNodes("./a[@target='_blank']");
song.NameHtml = links[0].InnerHtml;
if (links.Count > 1) song.MV = MVModel.GetNew(ParseXiamiIDString(links[1].GetAttributeValue("href", "/0")));
var anode = tds[3].Element("a");
var album = AlbumModel.GetNew(ParseXiamiID(anode.GetAttributeValue("href", "/0")));
album.NameHtml = anode.InnerHtml.Replace("《", "").Replace("》", "");
var arnode = tds[2].Element("a");
album.Artist = ArtistModel.GetNew(ParseXiamiID(arnode.GetAttributeValue("href", "/0")));
album.Artist.NameHtml = arnode.InnerHtml;
song.Album = album;
return song;
}
示例8: getVideoInfo
private VideoInfo getVideoInfo(HtmlNode itemDiv)
{
VideoInfo video = new VideoInfo();
video.VideoUrl = itemDiv.Elements("div").Last().GetAttributeValue("arte_vp_url", "");
video.Length = itemDiv.Descendants("div").Where(d => d.GetAttributeValue("class", "").Contains("badge-holder")).FirstOrDefault().Element("div").NextSibling.InnerText.Trim().Trim('"').Trim();
video.Airdate = itemDiv.Descendants("p").FirstOrDefault().ChildNodes.LastOrDefault().InnerText.Trim();
video.Title = itemDiv.Descendants("h3").FirstOrDefault().InnerText.Trim();
video.Thumb = itemDiv.Element("img").GetAttributeValue("src", "");
video.Description = itemDiv.GetAttributeValue("data-description", "");
return video;
}
示例9: ParseGemTable
private IEnumerable<Task<ItemDB.Gem>> ParseGemTable(HtmlNode table)
{
return from row in table.Elements("tr").Skip(1)
select row.ChildNodes[0] into cell
select cell.SelectNodes("span/a[not(contains(@class, 'image'))]")[0] into nameNode
select _gemReader.FetchGemAsync(nameNode.InnerHtml);
}
示例10: GetColumnValues
/// <summary>
/// Gets all the column values from the li node (Aggregate)
/// </summary>
/// <param name="node">The Aggregate Node</param>
/// <param name="columnNumber">Desired Columne Number, 'all' or'1' for the name column</param>
/// <returns>Array of column values</returns>
/// <remarks>
/// Abstracted the getting the column values to here to follow OO SRP and
/// the column tag names are only maintained in a single place.
/// </remarks>
private string[] GetColumnValues(HtmlNode node, string columnNumber = "all")
{
// Using an array we can guarantee the order of the column values
var columnValues = new string[10];
// Extract the elements from the column <p> tags
var columns = node.Elements("p");
// Use foreach so there is only one iteration over the collection
// then we don't need to use .ToArray() to allow indexing;
foreach (var column in columns)
{
if (column.Attributes.Count > 0)
{
var colName = column.Attributes[0].Value;
var colAttributes = colName.Split(' ');
var colId = colAttributes[0];
switch (colId)
{
case "panel-column1":
/*
* HTML Agility Pack has a utility class HtmlEntity containing a static class
* DeEntitize, which decode html elements like replacing them with
* the appropriate character.
* */
var trimChars = new char[] { '\r', '\n', ' ' };
//var colValue = column.InnerText;
//var colValueTrimmed = colValue.Trim(trimChars);
//columnValues[0] = HtmlAgilityPack.HtmlEntity.DeEntitize(colValueTrimmed);
// If only interested in the name, the first column, then exit immediately
columnValues[0] = HtmlAgilityPack.HtmlEntity.DeEntitize(column.InnerText.Trim(trimChars));
if (columnNumber != "all")
return columnValues;
break;
case "panel-column2":
columnValues[1] = column.InnerText;
break;
case "panel-column3":
columnValues[2] = HtmlEntity.DeEntitize(column.InnerText);
break;
case "panel-column4":
columnValues[3] = column.InnerText;
break;
case "panel-column5":
columnValues[4] = column.InnerText;
break;
case "panel-column6":
columnValues[5] = column.InnerText;
break;
case "panel-column7":
columnValues[6] = column.InnerText;
break;
case "panel-column8":
columnValues[7] = column.InnerText;
break;
case "panel-column9":
columnValues[8] = column.InnerText;
break;
case "panel-column10":
columnValues[9] = column.InnerText;
break;
}
}
}
return columnValues;
}