国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

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

2020-01-04 17:12:36
字體:
供稿:網(wǎng)友

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

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

構(gòu)建XML文件

ElementTree(tag),其中tag表示根節(jié)點,初始化一個ElementTree對象。

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

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

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

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

#!/usr/bin/env python# -*- coding:utf-8 -*-from xml.etree import ElementTree as ETdef build_sitemap():  urlset = ET.Element("urlset")  #設(shè)置一個根節(jié)點,標簽為urlset  url = ET.SubElement(urlset,"url")  #在根節(jié)點urlset下建立子節(jié)點  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é)果如下圖所示:

python,xml模塊

解析和修改XML文件

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

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

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

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

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

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 安阳县| 府谷县| 江川县| 万山特区| 太保市| 克拉玛依市| 秭归县| 涞源县| 涟水县| 灵武市| 桦川县| 义马市| 定襄县| 临城县| 吴堡县| 宁乡县| 永丰县| 张家界市| 临湘市| 镇安县| 晋江市| 吴忠市| 江源县| 南召县| 轮台县| 清河县| 本溪市| 巴彦县| 武胜县| 景东| 阿克陶县| 房产| 常德市| 西乌珠穆沁旗| 栾川县| 敦化市| 禄丰县| 星子县| 古蔺县| 镇康县| 安西县|