Home Backend Development Python Tutorial [Python] Web Crawler (1): The meaning of crawling web pages and the basic composition of URLs

[Python] Web Crawler (1): The meaning of crawling web pages and the basic composition of URLs

Jan 21, 2017 pm 01:43 PM

1. The definition of web crawler

Web crawler, or Web Spider, is a very vivid name.

If the Internet is compared to a spider web, then a spider is a spider crawling around on the web.
Web spiders search for web pages through their link addresses.

Start from a certain page of the website (usually the homepage), read the content of the webpage, find other link addresses in the webpage,

and then use these link addresses to find the next webpage, so The loop continues until all web pages of this website have been crawled.

If the entire Internet is regarded as a website, then web spiders can use this principle to crawl all web pages on the Internet.

In this way, a web crawler is a crawler, a program that crawls web pages.

The basic operation of a web crawler is to crawl web pages.

So how can you get the page you want as you wish?

Let’s start with the URL.


2. The process of browsing the webpage

The process of crawling the webpage is actually the same as how readers usually use IE browser to browse the webpage.

For example, you enter the address www.baidu.com in the address bar of the browser.

The process of opening a web page is actually that the browser, as a browsing "client", sends a request to the server, "grabs" the server-side files locally, and then interprets and displays them.

HTML is a markup language that uses tags to mark content and parse and differentiate it.

The function of the browser is to parse the obtained HTML code, and then convert the original code into the website page we see directly.


3. Concepts and examples of URI and URL


To put it simply, URL is on the browser side Enter the string http://www.baidu.com.

Before understanding URL, we must first understand the concept of URI.

What is a URI?

Every resource available on the Web, such as HTML documents, images, video clips, programs, etc., is located by a Universal Resource Identifier (URI).

URI usually consists of three parts:

①The naming mechanism for accessing resources;

②The host name where the resource is stored;

③The name of the resource itself , represented by a path.

For example, the following URI:
http://www.why.com.cn/myhtml/html1223/

We can interpret it like this:

①This is a resource that can be accessed through the HTTP protocol,

②It is located on the host www.webmonkey.com.cn,

③Accessed through the path "/html/html40".


4. Understanding and examples of URL

URL is a subset of URI. It is the abbreviation of Uniform Resource Locator, translated as "Uniform Resource Locator".

In layman's terms, URL is a string describing information resources on the Internet. It is mainly used in various WWW client programs and server programs.

URLs can be used to describe various information resources in a unified format, including files, server addresses and directories, etc.


The general format of URL is (with square brackets [] optional):

protocol :// hostname[:port] / path / [;parameters][?query]#fragment


The URL format consists of three parts:

①The first part is the protocol (or service method) ).

②The second part is the IP address of the host where the resource is stored (sometimes including the port number).

③The third part is the specific address of the host resource, such as directory and file name, etc.

The first part and the second part are separated by the "://" symbol,

The second part and the third part are separated by the "/" symbol.

The first and second parts are indispensable, and the third part can sometimes be omitted.


5. Simple comparison of URL and URI


URI is a lower-level abstraction of URL, a kind of string Text standards.

In other words, URI belongs to the parent class, and URL belongs to the subclass of URI. URL is a subset of URI. The definition of

URI is: Uniform Resource Identifier; the definition of

URL is: Uniform Resource Locator.

The difference between the two is that URI represents the path to the request server and defines such a resource.

The URL also describes how to access this resource (http://).




Let’s take a look at a small example of two URLs.


1. URL example of HTTP protocol:
Use Hypertext Transfer Protocol HTTP to provide resources for hypertext information services.

Example: http://www.peopledaily.com.cn/channel/welcome.htm

The computer domain name is www.peopledaily.com.cn.

The hypertext file (file type is .html) is welcome.htm in the directory /channel.

This is a computer from the People's Daily of China.

Example: http://www.rol.cn.NET/talk/talk1.htm

The computer domain name is www.rol.cn.Net.

The hypertext file (file type is .html) is talk1.htm in the directory/talk.

This is the address of Ruide Chat Room. You can enter the first room of Ruide Chat Room from here.


2. File URL
When using URL to represent a file, the server mode is represented by file, followed by the host IP address, file access path (i.e. directory), file name and other information.

Sometimes directory and file names can be omitted, but the "/" symbol cannot be omitted.

Example: file://ftp.yoyodyne.com/pub/files/foobar.txt

The above URL represents the pub/files/ directory stored on the host ftp.yoyodyne.com A file under, the file name is foobar.txt.

Example: file://ftp.yoyodyne.com/pub

represents the directory/pub on the host ftp.yoyodyne.com.

Example: file://ftp.yoyodyne.com/

represents the root directory of the host ftp.yoyodyne.com.


The main processing object of the crawler is the URL. It obtains the required file content based on the URL address, and then further processes it.

Therefore, accurately understanding URLs is crucial to understanding web crawlers.

The above is [Python] web crawler (1): crawling the meaning of web pages and the basic composition of URLs. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

How to train PyTorch model on CentOS How to train PyTorch model on CentOS Apr 14, 2025 pm 03:03 PM

Efficient training of PyTorch models on CentOS systems requires steps, and this article will provide detailed guides. 1. Environment preparation: Python and dependency installation: CentOS system usually preinstalls Python, but the version may be older. It is recommended to use yum or dnf to install Python 3 and upgrade pip: sudoyumupdatepython3 (or sudodnfupdatepython3), pip3install--upgradepip. CUDA and cuDNN (GPU acceleration): If you use NVIDIAGPU, you need to install CUDATool

Detailed explanation of docker principle Detailed explanation of docker principle Apr 14, 2025 pm 11:57 PM

Docker uses Linux kernel features to provide an efficient and isolated application running environment. Its working principle is as follows: 1. The mirror is used as a read-only template, which contains everything you need to run the application; 2. The Union File System (UnionFS) stacks multiple file systems, only storing the differences, saving space and speeding up; 3. The daemon manages the mirrors and containers, and the client uses them for interaction; 4. Namespaces and cgroups implement container isolation and resource limitations; 5. Multiple network modes support container interconnection. Only by understanding these core concepts can you better utilize Docker.

How is the GPU support for PyTorch on CentOS How is the GPU support for PyTorch on CentOS Apr 14, 2025 pm 06:48 PM

Enable PyTorch GPU acceleration on CentOS system requires the installation of CUDA, cuDNN and GPU versions of PyTorch. The following steps will guide you through the process: CUDA and cuDNN installation determine CUDA version compatibility: Use the nvidia-smi command to view the CUDA version supported by your NVIDIA graphics card. For example, your MX450 graphics card may support CUDA11.1 or higher. Download and install CUDAToolkit: Visit the official website of NVIDIACUDAToolkit and download and install the corresponding version according to the highest CUDA version supported by your graphics card. Install cuDNN library:

Python vs. JavaScript: Community, Libraries, and Resources Python vs. JavaScript: Community, Libraries, and Resources Apr 15, 2025 am 12:16 AM

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

How to choose the PyTorch version under CentOS How to choose the PyTorch version under CentOS Apr 14, 2025 pm 02:51 PM

When selecting a PyTorch version under CentOS, the following key factors need to be considered: 1. CUDA version compatibility GPU support: If you have NVIDIA GPU and want to utilize GPU acceleration, you need to choose PyTorch that supports the corresponding CUDA version. You can view the CUDA version supported by running the nvidia-smi command. CPU version: If you don't have a GPU or don't want to use a GPU, you can choose a CPU version of PyTorch. 2. Python version PyTorch

MiniOpen Centos compatibility MiniOpen Centos compatibility Apr 14, 2025 pm 05:45 PM

MinIO Object Storage: High-performance deployment under CentOS system MinIO is a high-performance, distributed object storage system developed based on the Go language, compatible with AmazonS3. It supports a variety of client languages, including Java, Python, JavaScript, and Go. This article will briefly introduce the installation and compatibility of MinIO on CentOS systems. CentOS version compatibility MinIO has been verified on multiple CentOS versions, including but not limited to: CentOS7.9: Provides a complete installation guide covering cluster configuration, environment preparation, configuration file settings, disk partitioning, and MinI

How to install nginx in centos How to install nginx in centos Apr 14, 2025 pm 08:06 PM

CentOS Installing Nginx requires following the following steps: Installing dependencies such as development tools, pcre-devel, and openssl-devel. Download the Nginx source code package, unzip it and compile and install it, and specify the installation path as /usr/local/nginx. Create Nginx users and user groups and set permissions. Modify the configuration file nginx.conf, and configure the listening port and domain name/IP address. Start the Nginx service. Common errors need to be paid attention to, such as dependency issues, port conflicts, and configuration file errors. Performance optimization needs to be adjusted according to the specific situation, such as turning on cache and adjusting the number of worker processes.

See all articles