When working with web scraping or manipulating HTML content in Go, you might often need to extract the content inside thetag and convert it into a string. This can be particularly useful when you want to process or analyze the body content of web pages. In this blog post, we’ll walk through how to achieve this using Go.

Prerequisites

Before we dive into the code, make sure you have Go installed on your machine. If not, you can download it from the official Go website.

We’ll also be using the following packages:

net/http for making HTTP requests.
golang.org/x/net/html for parsing the HTML content.
You can install the html package from golang.org/x/net using the following command:

bash
go get golang.org/x/net/html
Step-by-Step Guide

Step 1: Fetch the HTML Content

First, we need to fetch the HTML content of the web page. We’ll use the http package for this.

package main
import (
    "fmt"
    "net/http"
    "io/ioutil"
)

func fetchHTML(url string) (string, error) {
    resp, err := http.Get(url)
    if err != nil {
        return "", err
    }
    defer resp.Body.Close()
    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        return "", err
    }
    return string(body), nil
}

func main() {
    url := "http://example.com"
    htmlContent, err := fetchHTML(url)
    if err != nil {
        fmt.Println("Error fetching HTML:", err)
        return
    }
    fmt.Println(htmlContent)
}

 

Step 2: Parse the HTML and Extract the Body Content

Next, we’ll parse the HTML content and extract the content inside the tag. For this, we’ll use the html package.

package main

import (
    "fmt"
    "net/http"
    "io/ioutil"
    "golang.org/x/net/html"
    "bytes"
)

func fetchHTML(url string) (string, error) {
    resp, err := http.Get(url)
    if err != nil {
        return "", err
    }
    defer resp.Body.Close()

    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        return "", err
    }

    return string(body), nil
}

func extractBodyContent(htmlContent string) (string, error) {
    doc, err := html.Parse(bytes.NewReader([]byte(htmlContent)))
    if err != nil {
        return "", err
    }

    var bodyContent string
    var f func(*html.Node)
    f = func(n *html.Node) {
        if n.Type == html.ElementNode && n.Data == "body" {
            for c := n.FirstChild; c != nil; c = c.NextSibling {
                var buf bytes.Buffer
                html.Render(&buf, c)
                bodyContent += buf.String()
            }
        }
        for c := n.FirstChild; c != nil; c = c.NextSibling {
            f(c)
        }
    }
    f(doc)
    return bodyContent, nil
}
func main() {
    url := "http://example.com"
    htmlContent, err := fetchHTML(url)
    if err != nil {
        fmt.Println("Error fetching HTML:", err)
        return
    }
    bodyContent, err := extractBodyContent(htmlContent)
    if err != nil {
        fmt.Println("Error extracting body content:", err)
        return
    }
    fmt.Println(bodyContent)
}

Explanation
Fetching HTML Content: We make an HTTP GET request to the specified URL and read the response body.

Parsing HTML: We parse the HTML content using html.Parse.

Extracting Body Content: We traverse the parsed HTML nodes to find the tag. Once found, we extract its inner content by rendering each child node of the tag back to a string.

Running the Code
To run the code, simply save it to a file, for example main.go, and execute it using the following command:

bash

go run main.go
Replace http://example.com with the URL of the web page you want to process.

Conclusion

In this blog post, we’ve shown how to fetch HTML content from a web page and extract the content inside the tag as a string using Go. This method can be particularly useful for web scraping and HTML content processing. With the power of Go’s standard library and the golang.org/x/net/html package, handling and manipulating HTML content becomes straightforward and efficient.

Support On Demand!

Golang

Related Q&A