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

Python常用內(nèi)置模塊之xml模塊(詳解)

 更新時(shí)間:2017年05月23日 08:31:40   投稿:jingxian  
下面小編就為大家?guī)硪黄狿ython常用內(nèi)置模塊之xml模塊(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

xml即可擴(kuò)展標(biāo)記語言,它可以用來標(biāo)記數(shù)據(jù)、定義數(shù)據(jù)類型,是一種允許用戶對(duì)自己的標(biāo)記語言進(jìn)行定義的源語言。從結(jié)構(gòu)上,很像HTML超文本標(biāo)記語言。但他們被設(shè)計(jì)的目的是不同的,超文本標(biāo)記語言被設(shè)計(jì)用來顯示數(shù)據(jù),其焦點(diǎn)是數(shù)據(jù)的外觀。它被設(shè)計(jì)用來傳輸和存儲(chǔ)數(shù)據(jù),其焦點(diǎn)是數(shù)據(jù)的內(nèi)容。那么Python是如何處理XML語言文件的呢?下面一起來看看Python常用內(nèi)置模塊之xml模塊吧。

本文主要學(xué)習(xí)的ElementTree是python的XML處理模塊,它提供了一個(gè)輕量級(jí)的對(duì)象模型。在使用ElementTree模塊時(shí),需要import xml.etree.ElementTree的操作。ElementTree表示整個(gè)XML節(jié)點(diǎn)樹,而Element表示節(jié)點(diǎn)數(shù)中的一個(gè)單獨(dú)的節(jié)點(diǎn)。

構(gòu)建XML文件

ElementTree(tag),其中tag表示根節(jié)點(diǎn),初始化一個(gè)ElementTree對(duì)象。

Element(tag, attrib={}, **extra)函數(shù)用來構(gòu)造XML的一個(gè)根節(jié)點(diǎn),其中tag表示根節(jié)點(diǎn)的名稱,attrib是一個(gè)可選項(xiàng),表示節(jié)點(diǎn)的屬性。

SubElement(parent, tag, attrib={}, **extra)用來構(gòu)造一個(gè)已經(jīng)存在的節(jié)點(diǎn)的子節(jié)點(diǎn) Element.text和SubElement.text表示element對(duì)象的額外的內(nèi)容屬性,Element.tag和Element.attrib分別表示element對(duì)象的標(biāo)簽和屬性。

ElementTree.write(file, encoding='us-ascii', xml_declaration=None, default_namespace=None, method='xml'),函數(shù)新建一個(gè)XML文件,并且將節(jié)點(diǎn)數(shù)數(shù)據(jù)寫入XML文件中。

下面以新建一個(gè)網(wǎng)站的sitemap.xml文件為例進(jìn)行代碼示例

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from xml.etree import ElementTree as ET
def build_sitemap():
  urlset = ET.Element("urlset")  #設(shè)置一個(gè)根節(jié)點(diǎn),標(biāo)簽為urlset
  url = ET.SubElement(urlset,"url")  #在根節(jié)點(diǎn)urlset下建立子節(jié)點(diǎn)
  loc = ET.SubElement(url,"loc")
  loc.text = "http://www/baidu.com"
  lastmod = ET.SubElement(url,"lastmod")
  lastmod.text = "2017-10-10"
  changefreq = ET.SubElement(url,"changefreq")
  changefreq.text = "daily"
  priority = ET.SubElement(url,"priority")
  priority.text = "1.0"
  tree = ET.ElementTree(urlset)
  tree.write("sitemap.xml")
if __name__ == '__main__':
  build_sitemap()

結(jié)果如下圖所示:

解析和修改XML文件

ElementTree.parse(source, parser=None),將xml文件加載并返回ElementTree對(duì)象。parser是一個(gè)可選的參數(shù),如果為空,則默認(rèn)使用標(biāo)準(zhǔn)的XMLParser解析器。

ElementTree.getroot(),得到根節(jié)點(diǎn)。返回根節(jié)點(diǎn)的element對(duì)象。

Element.remove(tag),刪除root下名稱為tag的子節(jié)點(diǎn) 以下函數(shù),ElementTree和Element的對(duì)象都包含。

find(match),得到第一個(gè)匹配match的子節(jié)點(diǎn),match可以是一個(gè)標(biāo)簽名稱或者是路徑。返回個(gè)element findtext(match,default=None),得到第一個(gè)配置的match的element的內(nèi)容 findall(match),得到匹配match下的所有的子節(jié)點(diǎn),match可以是一個(gè)標(biāo)簽或者是路徑,它會(huì)返回一個(gè)list,包含匹配的elements的信息 iter(tag),創(chuàng)建一個(gè)以當(dāng)前節(jié)點(diǎn)為根節(jié)點(diǎn)的iterator。

還是以上面創(chuàng)建的sitemap.xml為例,對(duì)其進(jìn)行一定的修改,代碼示例如下:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
 
from xml.etree import ElementTree as ET
tree = ET.parse("sitemap.xml")
url = tree.find("url")
for rank in tree.iter('loc'):
  rank.text = "http://www.adminba.com"
tree.write("sitemap.xml")

以上的代碼將url修改為http://www.adminba.com了。另外,節(jié)點(diǎn)還有set(設(shè)置節(jié)點(diǎn)屬性)、attrib(刪除節(jié)點(diǎn)屬性)方法。

這篇Python常用內(nèi)置模塊之xml模塊(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python實(shí)現(xiàn)登錄接口的示例代碼

    Python實(shí)現(xiàn)登錄接口的示例代碼

    本篇文章主要介紹了Python實(shí)現(xiàn)登錄接口的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • 詳解Python如何實(shí)現(xiàn)惰性導(dǎo)入-lazy import

    詳解Python如何實(shí)現(xiàn)惰性導(dǎo)入-lazy import

    如果你的 Python 程序程序有大量的 import,而且啟動(dòng)非常慢,那么你應(yīng)該嘗試懶導(dǎo)入,本文分享一種實(shí)現(xiàn)惰性導(dǎo)入的一種方法,需要的可以參考一下
    2022-10-10
  • python?中pass和match使用方法

    python?中pass和match使用方法

    這篇文章主要介紹了python中pass和match使用方法,?pass???語句不執(zhí)行任何操作。語法上需要一個(gè)語句,但程序不實(shí)際執(zhí)行任何動(dòng)作時(shí),可以使用該語句
    2022-08-08
  • 使用python根據(jù)端口號(hào)關(guān)閉進(jìn)程的方法

    使用python根據(jù)端口號(hào)關(guān)閉進(jìn)程的方法

    今天小編就為大家分享一篇使用python根據(jù)端口號(hào)關(guān)閉進(jìn)程的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11
  • Python爬取微信小程序通用方法代碼實(shí)例詳解

    Python爬取微信小程序通用方法代碼實(shí)例詳解

    這篇文章主要介紹了Python爬取微信小程序通用方法代碼實(shí)例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Python使用Selenium實(shí)現(xiàn)瀏覽器打印預(yù)覽功能

    Python使用Selenium實(shí)現(xiàn)瀏覽器打印預(yù)覽功能

    在Web開發(fā)中,打印預(yù)覽是一個(gè)常見的功能需求,通過打印預(yù)覽,我們可以預(yù)覽和調(diào)整網(wǎng)頁的打印布局、樣式和內(nèi)容,Python的Selenium庫是一個(gè)強(qiáng)大的工具,可以自動(dòng)化瀏覽器操作,包括打印預(yù)覽,本文將介紹如何使用Python Selenium庫來實(shí)現(xiàn)瀏覽器的打印預(yù)覽功能
    2023-11-11
  • 淺談PyQt5 的幫助文檔查找方法,可以查看每個(gè)類的方法

    淺談PyQt5 的幫助文檔查找方法,可以查看每個(gè)類的方法

    今天小編就為大家分享一篇淺談PyQt5 的幫助文檔查找方法,可以查看每個(gè)類的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • 如何使用Python的OpenCV庫處理圖像和視頻

    如何使用Python的OpenCV庫處理圖像和視頻

    基于opencv可以顯示圖片,并進(jìn)行相應(yīng)的處理,下面這篇文章主要給大家介紹了關(guān)于如何使用Python的OpenCV庫處理圖像和視頻的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Python標(biāo)準(zhǔn)庫pickle的簡(jiǎn)單使用

    Python標(biāo)準(zhǔn)庫pickle的簡(jiǎn)單使用

    本文主要介紹了Python標(biāo)準(zhǔn)庫pickle的簡(jiǎn)單使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • python反轉(zhuǎn)(逆序)字符串的6種方法詳細(xì)

    python反轉(zhuǎn)(逆序)字符串的6種方法詳細(xì)

    這篇文章主要介紹了python反轉(zhuǎn)(逆序)字符串的6種方法詳細(xì),需要的朋友可以參考下
    2021-04-04

最新評(píng)論