0
我是OOP編程的新手,我想知道是否有人可以幫助我我一直在編寫一些代碼,並且我意識到有很多重複的東西需要該程序來完成;如何停止重複代碼
class scrape
{
public void parse()
{
string Url = "http://www.blah.co.uk/";
HtmlWeb web = new HtmlWeb();
HtmlDocument doc = web.Load(Url);
Console.WriteLine("URL Loaded,");
scrape scrape = new scrape();
scrape.cats(doc);
}
private void cats(HtmlDocument doc)
{
HtmlNode topcats = doc.GetElementbyId("main_nav");
if (topcats != null)
{
IEnumerable<HtmlNode> topnav = topcats.Descendants("a");
foreach (var toplink in topnav)
{
if (toplink.Attributes.Contains("href"))
{
if (toplink.Attributes["href"].Value.EndsWith(".html"))
{
Console.WriteLine("http://www.blah.co.uk/" + toplink.Attributes["href"].Value);
Console.WriteLine("++++++++ " + toplink.InnerText + " +++++++++++");
//sub cats
HtmlWeb cat_web = new HtmlWeb();
HtmlDocument cat_doc = cat_web.Load("http://www.blah.co.uk/" + toplink.Attributes["href"].Value);
HtmlNode subcats = cat_doc.GetElementbyId("pagenav");
if (subcats != null)
{
IEnumerable<HtmlNode> subnav = subcats.Descendants("a");
foreach (var sublink in subnav)
{
if (sublink.Attributes.Contains("href"))
{
if (sublink.Attributes["href"].Value.EndsWith(".html"))
{
Console.WriteLine("http://www.blah.co.uk/" +sublink.Attributes["href"].Value);
Console.WriteLine(sublink.InnerText);
}
}
}
}
}
}
}
}
Console.ReadLine();
}
}
}
從上面可以有一個人請幫我減少代碼重複,我怎麼能去在C#這樣做。任何幫助或信息將不勝感激謝謝。
您可以使用XPath而不是手動遍歷DOM。 – Dai
我會通過反轉if語句來減少縮進,所以它更容易閱讀。即'if(topcats == null)return;'或'if(!toplink.Attributes.Contains(「href」))continue;' –
您應該在[Code Review Stack Exchange]上發佈這個代碼(http:// codereview .stackexchange.com /)網站 –