Python筆記(十三):urllib模塊

来源:https://www.cnblogs.com/simple-free/archive/2018/04/28/8966795.html
-Advertisement-
Play Games

(一) URL地址 URL地址組件 URL組件 說明 scheme 網路協議或下載方案 net_loc 伺服器所在地(也許含有用戶信息) path 使用(/)分割的文件或CGI應用的路徑 params 可選參數 query 連接符(&)分割的一系列鍵值對 fragment 指定文檔內特定錨的部分 n ...


(一)      URL地址

URL地址組件

URL組件

說明

scheme

網路協議或下載方案

net_loc

伺服器所在地(也許含有用戶信息)

path

使用(/)分割的文件或CGI應用的路徑

params

可選參數

query

連接符(&)分割的一系列鍵值對

fragment

指定文檔內特定錨的部分

net_loc組件

user:password@host:port

組件

說明

user

用戶名或登錄

password

用戶密碼

host

運行web伺服器的電腦名稱或地址(必需)

port

埠號(如果不是預設的80)

 

(二)      urllib

    這裡主要說明urllib.request和urllib.parse.

(三)      urllib.request

urllib.request

組件

說明

urlopen(url,data=None)

打開URL鏈接,並返回一個文件類型對象,就像open用二進位只讀方式在本地打開了一個文件一樣。

url:可以是url字元串,也可以是請求對象

data:url是post請求時,可以指定要傳的數據

urlretrieve(url,filename=None)

下載url中的文件

filename:文件名及路徑(沒有指定路徑則存放到當前工作目錄下)

urlopen對象方法

組件

說明

read()

讀取所有數據

readline()

讀取一行數據

readlines()

讀取所有行,作為列表返回

fileno()

返迴文件句柄

close()

關閉url連接(close及上面4個方法和open的同名方法是一樣的)

info()

返回MIME(多目標網際網路郵件擴展)頭文件。這個頭文件通知瀏覽器返回的文件類型、以及可用哪類應用程式打開。

geturl()

返回真正的url(例如如果出現重定向,就可以從最終打開的文件中獲得真正的url)

getcode()

返回HTTP狀態碼


1
import urllib.request 2 url = 'https://tieba.baidu.com/p/5475267611' 3 #打開url(就像用open二進位只讀方式打開一個文件一樣),使用read讀取所有數據 4 html = urllib.request.urlopen(url).read() 5 print(type(html)) 6 7 url_file = 'https://imgsa.baidu.com/forum/w%3D580/sign=99114e38abec08fa260013af69ef3d4d/e549b13533fa828bc80c7764f61f4134960a5a85.jpg' 8 #下載url中的文件並保存 9 urllib.request.urlretrieve(url_file,'C:\Temp\\1.jpg') 10 11 #返回MIEM頭文件 12 html_info = urllib.request.urlopen(url).info() 13 print(html_info)

(四)      urlib.parse

urlib.parse

函數

說明

urlparse(urlstr)

將url解析為一個元組(scheme='', netloc='', path='', params='', query='', fragment='')

urlunparse(urltup)

和urlparse相反,將url組件(一個元組)拼接為完整的url

urljoin(base,url)

將base的根功能變數名稱和url拼接為一個完整的url

base:函數會自動截取net_loc及前面的所有內容


1
import urllib.parse 2 3 url = 'https://www.cnblogs.com/cate/python/' 4 newurl = '/cate/ruby/' 5 #將url解析為一個元組(scheme='', netloc='', path='', params='', query='', fragment='') 6 urlpar = urllib.parse.urlparse(url) 7 print('urlparse示例:',urlpar) 8 #和urlparse剛好相反,將元組(scheme='', netloc='', path='', params='', query='', fragment='')拼接為完整的url 9 urlunp = urllib.parse.urlunparse(urlpar) 10 print('urlunparse示例:',urlunp) 11 #將url netloc及前面部分的內容與newurl連接起來 12 url_ruby = urllib.parse.urljoin(url,newurl) 13 print('urljoin示例:',url_ruby)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本示例以“前後端分離模式”進行演示,調試用的異常信息通過日誌的形式列印出來,代碼並不完整,僅從異常處理進行部分代碼示例。 ...
  • 1、數組 概念:一個存儲元素的線性集合。 數組聲明和創建: 二維數組(多維數組)聲明和創建: PS:數組長度必現確定的。 2、列表 概念:列表是一組有序的數據。 常用實現:ArrayList、LinkedList。 3、棧 概念:棧是一種後入先出的數據結構。 常見實現:Stack(java.util ...
  • 上一篇文章鏈接: "模仿天貓實戰【SSM版】——項目起步" 後臺需求分析 在開始碼代碼之前,還是需要先清楚自己要做什麼事情,後臺具體需要實現哪些功能: 註意: 訂單、用戶、訂單、推薦鏈接均不提供增刪的功能。 後臺界面設計 不像前端那樣有原型直接照搬就可以了,後臺的設計還真的有難到我...畢竟我是一個 ...
  • 接著之前的文章:php根據命令行參數生成配置文件 ghostinit.php ...
  • 包是一種通過使用‘.模塊名’來組織python模塊名稱空間的方式。 1. 無論是import形式還是from...import形式, 凡是在導入語句中(而不是在使用時)遇到帶點的,都要第一時間提高警覺:這是關於包才有的導入語法。 2. 包是目錄級的(文件夾級),文件夾是用來組成py文件(包的本質就是... ...
  • 以下代碼可以去掉註釋單獨運行: ...
  • 題目背景 動態樹 題目描述 給定n個點以及每個點的權值,要你處理接下來的m個操作。操作有4種。操作從0到3編號。點從1到n編號。 0:後接兩個整數(x,y),代表詢問從x到y的路徑上的點的權值的xor和。保證x到y是聯通的。 1:後接兩個整數(x,y),代表連接x到y,若x到y已經聯通則無需連接。 ...
  • 【聲明】歡迎轉載,但請保留文章原始出處→_→ 秦學苦練:http://www.cnblogs.com/Qinstudy/ 文章來源:http://www.cnblogs.com/Qinstudy/p/Qinstudy.html 【正文】 秦學苦練博主,你好!我是立志要掌握Java編程語言的一名小白, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...