David's Blog

Scrapping in C#

By David Li on Tues, 21 November 2023

Web scraping is a technique used to extract data from websites. It can be done manually by a user or automatically by a program. In this post, we’ll explore how to perform web scraping using C#.

First, let’s understand the basics of web scraping. When we visit a website, our web browser sends a request to the server hosting the website. The server responds with the HTML, CSS, and JavaScript files that make up the website. Our web browser then renders the website based on these files.

Web scraping works in a similar way. Instead of a web browser, we use a program to send a request to the server and receive the response. We can then parse the HTML to extract the data we need.

In C#, we can use the HttpClient class to send HTTP requests and receive responses. Here’s an example of how to send a GET request to a website and receive the response:

using System.Net.Http;
using System.Threading.Tasks;

namespace WebScrapingExample
{
    public static async Task<string> GetWebsiteContentAsync(string url)
    {
        using (var client = new HttpClient())
        {
            var response = await client.GetAsync(url);
            response.EnsureSuccessStatusCode();
            return await response.Content.ReadAsStringAsync();
        }
    }
}

In this example, we create an instance of the HttpClient class and use its GetAsync method to send a GET request to the specified URL. We then use the EnsureSuccessStatusCode method to ensure that the response was successful. Finally, we use the ReadAsStringAsync method to read the response content as a string.

Once we have the HTML content of the website, we can use an HTML parser to extract the data we need. There are several HTML parsers available for C#, such as HtmlAgilityPack and AngleSharp.

HtmlAgilityPack

HtmlAgilityPack is an open-source HTML parser library for .NET that allows developers to parse, manipulate, and extract information from HTML documents. It provides a set of classes and methods that enable developers to easily traverse the HTML document structure, access and modify the HTML elements and attributes, and extract data from the document.

HtmlAgilityPack can be used in a wide range of applications, including web scraping, web development, and data analysis. It supports various HTML versions, including HTML 5, and provides a range of features for working with malformed or poorly structured HTML documents.

Some of the key features of HtmlAgilityPack include:

DOM traversal and manipulation: HtmlAgilityPack provides a rich set of classes and methods for traversing and manipulating the HTML document’s structure. It allows developers to access and modify HTML elements and attributes, and to add, remove, or modify nodes in the document.

XPath support: HtmlAgilityPack provides XPath support, which allows developers to query the HTML document using XPath expressions. This makes it easy to locate specific elements or attributes in the document and extract the information needed.

HTML validation: HtmlAgilityPack includes a built-in HTML validator that can be used to check whether an HTML document is well-formed and meets certain standards.

Character encoding support: HtmlAgilityPack supports various character encodings and can automatically detect the encoding of an HTML document.

Here’s an example of how to use HtmlAgilityPack to extract the titles of the articles on the front page of a news website:

using HtmlAgilityPack;

namespace WebScrapingExample
{
    public static List<string> GetArticleTitles(string html)
    {
        var doc = new HtmlDocument();
        doc.LoadHtml(html);

        var titles = new List<string>();
        foreach (var node in doc.DocumentNode.SelectNodes("//h2[@class='title']/a"))
        {
            titles.Add(node.InnerText);
        }

        return titles;
    }
}

In this example, we create an instance of the HtmlDocument class and use its LoadHtml method to load the HTML content. We then use the SelectNodes method to select the nodes that match the specified XPath expression. In this case, we’re selecting all a elements that are children of h2 elements with a class attribute of title. We then use the InnerText property to get the text content of each node and add it to a list.

That’s the basics of web scraping in C#! Of course, there’s a lot more to it, such as handling pagination, dealing with AJAX content, and respecting the website’s terms of service and robots.txt file. But this should give you a good starting point for your own web scraping projects.

Overall, LINQ is a powerful tool for web scraping that can be used to extract, transform, and analyze data in a flexible and efficient manner. Its ability to work with different data sources makes it a valuable tool for developers who need to extract data from web pages for further analysis or use.

© Copyright 2024 by FriendlyUsers Tech Blog. Built with ♥ by FriendlyUser. Last updated on 2024-12-23.