好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 利用Shell解析處理XML的方法匯總

利用Shell解析處理XML的方法匯總

熱門標簽:網絡電話外呼系統撥號軟件 申請400電話有什么用 貴陽400電話到哪里去辦理 天津智能外呼系統排名 400電話申請找 汨羅代理外呼系統 宿松高德地圖標注 4層電梯外呼控制系統設計 電銷機器人加盟多少錢

前言

前幾天在干活的時候遇到一個需要解析處理xml文件的一個需求,當時考慮到邏輯比較復雜,因此用java慢慢搞了搞。不過這個需求經常會變,每次變化之后都要重新找到jar包的代碼,改了之后還要替換原來的jar包,一來不方便修改,二來不方便統一保存代碼,三來也不方便查看jar包的功能。

其實對于這種比較靈活的功能,最方便高效的做法是采用一些腳本語言,比如python,ruby等等,開發效率高,而且也能處理一些復雜邏輯。但是由于種種原因,工作中有的機器沒有安裝這些語言的解釋器。因此不得已,研究了一波用shell腳本解析xml的方法。

說到底,shell還是不太適合處理復雜的邏輯,但是對于一些簡單的查找替換等需求,用shell來搞還是挺方便的。

我這里主要采用了下面三個工具:

  • xmllint
  • xpath
  • xml2

下面就分別總結下這三個工具的用法,方便以后查閱。

xmllint

簡述

xmllint其實是由一個叫libxml2的c語言庫函數實現的一個小工具,因此效率比較高,對不同系統的支持度也很好,功能也比較全。他一般屬于libxml2-utils這個軟件包,因此類似與sudo apt install libxml2-utils的命令就可以安裝。

功能

xmllint至少支持下面幾個常用功能:

  • 支持xpath查詢語句
  • 支持類shell的交互式查詢
  • 支持xml格式驗證
  • 支持dtd,xsd對xml的校驗
  • 支持編碼轉換
  • 支持xml格式化
  • 支持去空格壓縮
  • 支持時間效率統計

其實我們比較常用的功能主要也就是三個–xpath查詢、去空格和格式化、校驗。

比如當前有sample.xml:

books>
  book id="1">
    name>book1/name>
    price>100/price>
  /book>
  book id="2">
    name>book2/name>
    price>200/price>
  /book>
  book id="3">name>book3/name>price>300/price>
  /book>
/books>

執行xpath查詢:

myths@business:~$ xmllint --xpath "http://book[@id=2]/name/text()" sample.xml
book2

去空格:

myths@business:~$ xmllint --noblanks sample.xml
?xml version="1.0"?>
books>book id="1">name>book1/name>price>100/price>license/>/book>book id="2">name>book2/name>price>200/price>/book>book id="3">name>book3/name>price>300/price>/book>/books>

格式化:

myths@business:~$ xmllint --format sample.xml
?xml version="1.0"?>
books>
 book id="1">
 name>book1/name>
 price>100/price>
 license/>
 /book>
 book id="2">
 name>book2/name>
 price>200/price>
 /book>
 book id="3">
 name>book3/name>
 price>300/price>
 /book>
/books>

xsd校驗:

myths@business:~$ cat sample.xsd
?xml version="1.0" encoding="utf-8"?>
xs:schema id="books" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
 xs:element name="books" msdata:IsDataSet="true" msdata:Locale="en-US">
 xs:complexType>
  xs:choice minOccurs="0" maxOccurs="unbounded">
  xs:element name="book">
   xs:complexType>
   xs:sequence>
    xs:element name="name" type="xs:string" minOccurs="0" msdata:Ordinal="0" />
    xs:element name="price" type="xs:string" minOccurs="0" msdata:Ordinal="1" />
   /xs:sequence>
   xs:attribute name="id" type="xs:string" />
   /xs:complexType>
  /xs:element>
  /xs:choice>
 /xs:complexType>
 /xs:element>
/xs:schema>
 
myths@business:~$ xmllint --noout --schema sample.xsd sample.xml
sample.xml validates

注意:校驗結果信息是輸出到stderr中的,工具默認會把原文件回顯到stdout里,可以加–noout參數關閉stdout回顯。

流傳遞:

xmllint默認是傳遞文件名,如果我們希望用通過管道傳遞文件流的方式傳遞數據,我們可以這樣弄:

myths@business:~$ cat sample.xml |xmllint --format -
?xml version="1.0"?>
?xml version="1.0"?>
books>
 book id="1">
 name>book1/name>
 price>100/price>
 license/>
 /book>
 book id="2">
 name>book2/name>
 price>200/price>
 /book>
 book id="3">
 name>book3/name>
 price>300/price>
 /book>
/books>

xpath

簡述

xpath工具其實是封裝了的perl腳本,本身也只有兩百來行,功能比較專一,就是提供xpath的查詢功能。他一般屬于libxml-xpath-perl這個軟件包,因此類似于sudo apt install libxml-xpath-perl的命令就可以安裝。像suse之類的系統還會直接自帶。

功能

不同系統中安裝的版本可能不同,不過基本功能是類似的:

myths@business:~$ xpath -e '//book/name/text()' sample.xml
Found 3 nodes in sample.xml:
-- NODE --
book1
-- NODE --
book2
-- NODE --
book3

默認會將查詢呢結果輸出到stdout中,將說明信息輸出到stderr中。如果為了方便收集結果,可以將stderr重定向到/dev/null,或者加上-q參數:

myths@business:~$ xpath -e '//book/name/text()' sample.xml 2>/dev/null
book1
book2
book3
myths@business:~$ xpath -q -e '//book/name/text()' sample.xml
book1
book2
book3

xpath相比xmllint的xpath功能有一點點區別很重要,如果xpath匹配了多個結果,那么xpath就會分行輸出,而xmllint則會揉到一行:

myths@business:~$ xmllint --xpath "http://book/name/text()" sample.xml
book1book2book3

xml2

簡述

xml2這個工具感覺知道的人并不多,不過其實他在某些場景里跟其他命令配合能起到奇效。這個工具的開發人員的博客似乎已經掛掉了,不過目測應該用C以及libxml2庫寫的一個小工具。一般是在xml2軟件包中,因此類似sudo apt install xml2的命令就可以安裝。

功能

這個工具包含六個命令:xml2,2xml,html2,2html,csv2,2csv,功能也非常unix,就是分別將xml,html,csv格式與一種他稱之為“flat format”的格式進行轉換。舉個例子:

myths@business:~$ cat sample.xml |xml2
/books/book/@id=1
/books/book/name=book1
/books/book/price=100
/books/book
/books/book/@id=2
/books/book/name=book2
/books/book/price=200
/books/book
/books/book/@id=3
/books/book/name=book3
/books/book/price=300
myths@business:~$ cat sample.xml |xml2|2xml
books>book id="1">name>book1/name>price>100/price>/book>book id="2">name>book2/name>price>200/price>/book>book id="3">name>book3/name>price>300/price>/book>/books>

這種自定義的格式非常簡單而巧妙,有的表示新建節點(/books/book),有的表示給節點賦值(/books/book/name=book1),有的表示給節點的屬性賦值(/books/book/@id=1)。寫法跟xpath很像但又不完全一樣。而且相互對應的兩個命令放在一起能做到冪等。

那么這種轉化命令有什么用呢?其實我們經常會遇到一些創建xml文件的需求,但是直接按照xml格式動態生成就非常麻煩,這時候用flat format做個中轉就非常方便了:

#!/usr/bin/env bash
tempFile=$(mktemp tmp.XXXX)
function addBook(){
 id=$1
 name=$2
 price=$3
 echo "/books/book">>$tempFile
 echo "/books/book/@id=$id">>$tempFile
 echo "/books/book/name=$name">>$tempFile
 echo "/books/book/price=$price">>$tempFile
}
function main(){
 addBook 1 book1 100
 addBook 2 book2 200
 addBook 3 book3 300
 cat $tempFile|2xml|xmllint --format --output new_sample.xml -
 rm $tempFile
}
main "$@"

上面這段代碼就生成了與sample.xml一模一樣的new_sample.xml.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • shell生成簡單格式的xml實例
  • shell腳本實現快速生成xml格式sitemap實例分享

標簽:臨沂 海北 昌都 撫州 廣東 贛州 烏蘭察布 連云港

巨人網絡通訊聲明:本文標題《利用Shell解析處理XML的方法匯總》,本文關鍵詞  利用,Shell,解析,處理,XML,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《利用Shell解析處理XML的方法匯總》相關的同類信息!
  • 本頁收集關于利用Shell解析處理XML的方法匯總的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中文字幕中国一及大毛片| 美女穿白丝撅屁股打屁股视频| 中国胖女人一级毛片aaaaa| 色婷婷综合成人AV视频| 日本乱人伦a综艺网站| 狠狠躁夜夜躁人人爽碰 | 撕开老师的丝袜白丝扒开粉嫩的小| 性之剧毒在线观看| 麻豆精品无码国产在线播放| 国产热の有码热の无码视频一区| 69精品久久久久| 福利区体验区120秒软件评价| 欧美黄色生活片| 床戏视频超长床戏视频| h嗯啊~乱女h| 亚洲精品www久久久久久 | 《炽热》大尺度片段| 啊好大好深| 国产经典三级在线| 国产在线不卡| 日本工番口番H漫画人妻| 极品美女一级毛片免费| 毛片免费网址| 西西熟女少妇大尺度毛毛| 酒井ももか无码AV在线播放| 性视频福利在线看| 又大又粗又长又深又猛| 女人被爽到高潮的乱码视频| 亚洲乱人伦片| 艳妇交换3p| 八戒八戒午夜私人理论片| 亚洲97在线| 欧美大逼| 内衣办公室1-3| 五十熟女水多毛多BBBBB| 中文字幕国内精品日本Av| 粉嫩白浆小泬150P| 国产女人JJIZZ多水喷水免费 | 美女的让男人桶到爽软件| 丝袜爱液粗大紧窄白浆| 黄色小视频在线观看免费|