欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python自動檢測requests所獲得html文檔的編碼

 更新時間:2024年11月18日 11:12:46   作者:Humbunklung  
這篇文章主要為大家詳細介紹了如何通過Python自動檢測requests實現(xiàn)獲得html文檔的編碼,文中的示例代碼講解詳細,感興趣的可以了解下

使用chardet庫自動檢測requests所獲得html文檔的編碼

使用requests和BeautifulSoup庫獲取某個頁面帶來的亂碼問題

使用requests配合BeautifulSoup庫,可以輕松地從網頁中提取數據。但是,當網頁返回的編碼格式與Python默認的編碼格式不一致時,就會導致亂碼問題。

以如下代碼為例,它會獲取到一段亂碼的html:

import requests
from bs4 import BeautifulSoup

# 目標 URL
url = 'https://finance.sina.com.cn/realstock/company/sh600050/nc.shtml'

# 發(fā)送 HTTP GET 請求
response = requests.get(url)

# 檢查請求是否成功
if response.status_code == 200:

    # 獲取網頁內容
    html_content = response.text
    
    # 使用 BeautifulSoup 解析 HTML 內容
    soup = BeautifulSoup(html_content, 'html.parser')
    
    # 要查找的 ID
    target_id = 'hqDetails'
    
    # 查找具有特定 ID 的標簽
    element = soup.find(id=target_id)
    
    if element:
        # 獲取該標簽下的 HTML 內容
        element_html = str(element)
        print(f"ID 為 {target_id} 的 HTML 內容:\n{element_html}\n")
        
        # 查找該標簽下的所有 table 元素
        tables = element.find_all('table')
        
        if tables:
            for i, table in enumerate(tables):
                print(f"第 {i+1} 個 table 的 HTML 內容:\n{table}\n")
        else:
            print(f"ID 為 {target_id} 的標簽下沒有 table 元素")
    else:
        print(f"未找到 ID 為 {target_id} 的標簽")
else:
    print(f"請求失敗,狀態(tài)碼: {response.status_code}")

我們可以通過通過手工指定代碼的方式來解決這個問題,例如在response.status_code == 200后,通過response.encoding = 'utf-8'指定代碼,又或通過soup = BeautifulSoup(html_content, 'html.parser', from_encoding='utf-8') 來指定編碼。

然而,當我們獲取的html頁面編碼不確定的時候,有沒有更好的辦法讓編碼監(jiān)測自動執(zhí)行呢?這時候chardet編碼監(jiān)測庫是一個很好的幫手。

使用 chardet 庫自動檢測編碼

chardet 是一個用于自動檢測字符編碼的庫,可以更準確地檢測響應的編碼。

安裝chardet庫

pip install chardet

代碼應用示例

import requests
from bs4 import BeautifulSoup
import chardet

# 目標 URL
url = 'https://finance.sina.com.cn/realstock/company/sh600050/nc.shtml'

# 發(fā)送 HTTP GET 請求
response = requests.get(url)

# 檢查請求是否成功
if response.status_code == 200:
    # 自動檢測字符編碼
    detected_encoding = chardet.detect(response.content)['encoding']
    
    # 設置響應的編碼
    response.encoding = detected_encoding

    # 獲取網頁內容
    html_content = response.text
    
    # 使用 BeautifulSoup 解析 HTML 內容
    soup = BeautifulSoup(html_content, 'html.parser')
    
    # 要查找的 ID
    target_id = 'hqDetails'
    
    # 查找具有特定 ID 的標簽
    element = soup.find(id=target_id)
    
    if element:
        # 獲取該標簽下的 HTML 內容
        element_html = str(element)
        print(f"ID 為 {target_id} 的 HTML 內容:\n{element_html}\n")
        
        # 查找該標簽下的所有 table 元素
        tables = element.find_all('table')
        
        if tables:
            for i, table in enumerate(tables):
                print(f"第 {i+1} 個 table 的 HTML 內容:\n{table}\n")
        else:
            print(f"ID 為 {target_id} 的標簽下沒有 table 元素")
    else:
        print(f"未找到 ID 為 {target_id} 的標簽")
else:
    print(f"請求失敗,狀態(tài)碼: {response.status_code}")

可見,通過使用chardet庫,可以有效實現(xiàn)代碼的自動檢測。

以上就是Python自動檢測requests所獲得html文檔的編碼的詳細內容,更多關于Python檢測requests獲得html文檔編碼的資料請關注腳本之家其它相關文章!

相關文章

  • Pytho常見的數據可視化庫,小白必備

    Pytho常見的數據可視化庫,小白必備

    Python作為數據分析的重要語言為數據分析的每個環(huán)節(jié)都提供了很多庫.常見的數據可視化庫包括matplotib,seaborm,ggplot,bokeh,pygal,pyecharts等,下面小編一一介紹下,需要的朋友可以參考下
    2021-05-05
  • pytorch: Parameter 的數據結構實例

    pytorch: Parameter 的數據結構實例

    今天小編就為大家分享一篇pytorch: Parameter 的數據結構實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • Python添加進度條tqdm進階使用實例

    Python添加進度條tqdm進階使用實例

    這篇文章主要為大家介紹了Python添加進度條tqdm進階使用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • Python爬蟲采集Tripadvisor數據案例實現(xiàn)

    Python爬蟲采集Tripadvisor數據案例實現(xiàn)

    這篇文章主要為大家介紹了Python爬蟲采集Tripadvisor數據案例實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • Python學生成績管理系統(tǒng)簡潔版

    Python學生成績管理系統(tǒng)簡潔版

    這篇文章主要為大家詳細介紹了簡潔版的Python學生成績管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Python學習之time模塊的基本使用

    Python學習之time模塊的基本使用

    這篇文章主要給大家介紹了關于Python學習之time模塊基本使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • python中下標和切片的使用方法解析

    python中下標和切片的使用方法解析

    這篇文章主要介紹了python中下標和切片的使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • 詳解python 一維、二維列表的初始化問題

    詳解python 一維、二維列表的初始化問題

    這篇文章主要介紹了python 一維、二維列表的初始化,本文通過兩種方式給大家詳細講解,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2022-06-06
  • python隨機生成庫faker庫api實例詳解

    python隨機生成庫faker庫api實例詳解

    今天小編就為大家分享一篇python隨機生成庫faker庫api實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python3.8對可迭代解包的改進及用法詳解

    Python3.8對可迭代解包的改進及用法詳解

    這篇文章主要介紹了Python3.8對可迭代解包的改進及用法詳解,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10

最新評論