0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

XML在HarmonyOS中的生成,解析與轉(zhuǎn)換(下)

王程 ? 來源: jf_75796907 ? 作者: jf_75796907 ? 2024-02-18 10:07 ? 次閱讀

一、XML 解析

對于以 XML 作為載體傳遞的數(shù)據(jù),實際使用中需要對相關(guān)的節(jié)點進行解析,一般包括解析 XML 標簽和標簽值、解析 XML 屬性和屬性值、解析 XML 事件類型和元素深度三類場景。

XML 模塊提供 XmlPullParser 類對 XML 文件解析,輸入為含有 XML 文本的 ArrayBuffer 或 DataView,輸出為解析得到的信息

表 1 XML 解析選項

名稱 類型 必填 說明
supportDoctype boolean 否 是否忽略文檔類型。默認為 false,表示對文檔類型進行解析。
ignoreNameSpace boolean 否 是否忽略命名空間。默認為 false,表示對命名空間進行解析。
tagValueCallbackFunction (name: string, value: string) => boolean 否 獲取 tagValue 回調(diào)函數(shù),打印標簽及標簽值。默認為 null,表示不進行 XML 標簽和標簽值的解析。
attributeValueCallbackFunction (name: string, value: string) => boolean 否 獲取 attributeValue 回調(diào)函數(shù), 打印屬性及屬性值。默認為 null,表示不進行 XML 屬性和屬性值的解析。
tokenValueCallbackFunction (eventType: EventType, value: ParseInfo) => boolean 否 獲取 tokenValue 回調(diào)函數(shù),打印標簽事件類型及 parseInfo 對應屬性。默認為 null,表示不進行 XML 事件類型解析。

注意事項

? ● XML 解析及轉(zhuǎn)換需要確保傳入的 XML 數(shù)據(jù)符合標準格式。

? ● XML 解析目前不支持按指定節(jié)點解析對應的節(jié)點值。

解析 XML 標簽和標簽值

? 1. 引入模塊。

import xml from '@ohos.xml';
import util from '@ohos.util'; // 需要使用util模塊函數(shù)對文件編碼

2.XML 文件編碼后調(diào)用 XmlPullParser。

可以基于 ArrayBuffer 構(gòu)造 XmlPullParser 對象, 也可以基于 DataView 構(gòu)造 XmlPullParser 對象。

let strXml =
  '' +
    '' +
    'Play' +
    'Work' +
    '';
let textEncoder = new util.TextEncoder();
let arrBuffer = textEncoder.encodeInto(strXml); // 對數(shù)據(jù)編碼,防止包含中文字符亂碼
// 1.基于ArrayBuffer構(gòu)造XmlPullParser對象
let that = new xml.XmlPullParser(arrBuffer.buffer, 'UTF-8');

// 2.基于DataView構(gòu)造XmlPullParser對象
let dataView = new DataView(arrBuffer.buffer);
let that = new xml.XmlPullParser(dataView, 'UTF-8');

? 3. 自定義回調(diào)函數(shù),本例直接打印出標簽及標簽值。

let str = '';
function func(name, value){
  str = name + value;
  console.info(str);
  return true; //true:繼續(xù)解析 false:停止解析
}

? 4. 設(shè)置解析選項,調(diào)用 parse 函數(shù)。

let options = {supportDoctype:true, ignoreNameSpace:true, tagValueCallbackFunction:func};
that.parse(options);

輸出結(jié)果如下所示:

note
title
Play
title
lens
Work
lens
note

解析 XML 屬性和屬性值

  1. 引入模塊。
import xml from '@ohos.xml';
import util from '@ohos.util'; // 需要使用util模塊函數(shù)對文件編碼
  1. 對 XML 文件編碼后調(diào)用 XmlPullParser。
let strXml =
  '' +
    '' +
    '    Play' +
    '    Happy' +
    '    Work' +
    '';
let textEncoder = new util.TextEncoder();
let arrBuffer = textEncoder.encodeInto(strXml); // 對數(shù)據(jù)編碼,防止包含中文字符亂碼
let that = new xml.XmlPullParser(arrBuffer.buffer, 'UTF-8');
  1. 自定義回調(diào)函數(shù),本例直接打印出屬性及屬性值。
let str = '';
function func(name, value){
  str += name + ' ' + value + ' ';
  return true; // true:繼續(xù)解析 false:停止解析
}
  1. 設(shè)置解析選項,調(diào)用 parse 函數(shù)。
let options = {supportDoctype:true, ignoreNameSpace:true, attributeValueCallbackFunction:func};
that.parse(options);
console.info(str); // 一次打印出所有的屬性及其值

輸出結(jié)果如下所示:

importance high logged true // note節(jié)點的屬性及屬性值

解析 XML 事件類型和元素深度

? 1. 引入模塊。

import xml from '@ohos.xml';
import util from '@ohos.util'; // 需要使用util模塊函數(shù)對文件編碼

? 2. 對 XML 文件編碼后調(diào)用 XmlPullParser。

let strXml =
  '' +
  '' +
  'Play' +
  '';
let textEncoder = new util.TextEncoder();
let arrBuffer = textEncoder.encodeInto(strXml); // 對數(shù)據(jù)編碼,防止包含中文字符亂碼
let that = new xml.XmlPullParser(arrBuffer.buffer, 'UTF-8');

? 3. 自定義回調(diào)函數(shù),本例直接打印元素事件類型及元素深度。

let str = '';
function func(name, value){
  str = name + ' ' + value.getDepth(); // getDepth 獲取元素的當前深度
  console.info(str)
  return true; //true:繼續(xù)解析 false:停止解析
}

? 4. 設(shè)置解析選項,調(diào)用 parse 函數(shù)。

let options = {supportDoctype:true, ignoreNameSpace:true, tokenValueCallbackFunction:func};
that.parse(options);

輸出結(jié)果如下所示:

0 0 // 0: 對應事件類型START_DOCUMENT值為0  0:起始深度為0
2 1 // 2: 對應事件類型START_TAG值為2       1:深度為1
2 2 // 2:對應事件類型START_TAG值為2                                       2:深度為2
4 2 // 4:Play對應事件類型TEXT值為4                                               2:深度為2
3 2 // 3:對應事件類型END_TAG值為3                                        2:深度為2
3 1 // 3:對應事件類型END_TAG值為3                                         1:深度為1(與)
1 0 // 1:對應事件類型END_DOCUMENT值為1                                           0:深度為0
場景示例

場景示例

此處以調(diào)用所有解析選項為例,提供解析 XML 標簽、屬性和事件類型的開發(fā)示例。

import xml from '@ohos.xml';
import util from '@ohos.util';

let strXml =
  '' +
    '' +
    'Everyday' +
    'Giada' +
    '';
let textEncoder = new util.TextEncoder();
let arrBuffer = textEncoder.encodeInto(strXml);
let that = new xml.XmlPullParser(arrBuffer.buffer, 'UTF-8');
let str = '';

function tagFunc(name, value) {
  str = name + value;
  console.info('tag-' + str);
  return true;
}

function attFunc(name, value) {
  str = name + ' ' + value;
  console.info('attri-' + str);
  return true;
}

function tokenFunc(name, value) {
  str = name + ' ' + value.getDepth();
  console.info('token-' + str);
  return true;
}

let options = {
  supportDocType: true,
  ignoreNameSpace: true,
  tagValueCallbackFunction: tagFunc,
  attributeValueCallbackFunction: attFunc,
  tokenValueCallbackFunction: tokenFunc
};
that.parse(options);

輸出結(jié)果如下所示:

tag-
token-0 0
tag-book
attri-category COOKING
token-2 1
tag-title
attri-lang en
token-2 2
tag-Everyday
token-4 2
tag-title
token-3 2
tag-author
token-2 2
tag-Giada
token-4 2
tag-author
token-3 2
tag-book
token-3 1
tag-
token-1 0

二、 XML 轉(zhuǎn)換

將 XML 文本轉(zhuǎn)換為 JavaScript 對象可以更輕松地處理和操作數(shù)據(jù),并且更適合在 JavaScript 應用程序中使用。

語言基礎(chǔ)類庫提供 ConvertXML 類將 XML 文本轉(zhuǎn)換為 JavaScript 對象,輸入為待轉(zhuǎn)換的 XML 字符串及轉(zhuǎn)換選項,輸出為轉(zhuǎn)換后的 JavaScript 對象。具體轉(zhuǎn)換選項可見 @ohos.convertxml。

注意事項

XML 解析及轉(zhuǎn)換需要確保傳入的 XML 數(shù)據(jù)符合標準格式。

開發(fā)步驟

此處以 XML 轉(zhuǎn)為 JavaScript 對象后獲取其標簽值為例,說明轉(zhuǎn)換效果。

? 1. 引入模塊。

import convertxml from '@ohos.convertxml';

? 2. 輸入待轉(zhuǎn)換的 XML,設(shè)置轉(zhuǎn)換選項。

let xml =
  '' +
    '' +
    '    Happy' +
    '    Work' +
    '    Play' +
    '';
let options = {
  // trim: false 轉(zhuǎn)換后是否刪除文本前后的空格,否
  // declarationKey: "_declaration" 轉(zhuǎn)換后文件聲明使用_declaration來標識
  // instructionKey: "_instruction" 轉(zhuǎn)換后指令使用_instruction標識
  // attributesKey: "_attributes" 轉(zhuǎn)換后屬性使用_attributes標識
  // textKey: "_text" 轉(zhuǎn)換后標簽值使用_text標識
  // cdataKey: "_cdata" 轉(zhuǎn)換后未解析數(shù)據(jù)使用_cdata標識
  // docTypeKey: "_doctype" 轉(zhuǎn)換后文檔類型使用_doctype標識
  // commentKey: "_comment" 轉(zhuǎn)換后注釋使用_comment標識
  // parentKey: "_parent" 轉(zhuǎn)換后父類使用_parent標識
  // typeKey: "_type" 轉(zhuǎn)換后元素類型使用_type標識
  // nameKey: "_name" 轉(zhuǎn)換后標簽名稱使用_name標識
  // elementsKey: "_elements" 轉(zhuǎn)換后元素使用_elements標識
  trim: false,
  declarationKey: "_declaration",
  instructionKey: "_instruction",
  attributesKey: "_attributes",
  textKey: "_text",
  cdataKey: "_cdata",
  docTypeKey: "_doctype",
  commentKey: "_comment",
  parentKey: "_parent",
  typeKey: "_type",
  nameKey: "_name",
  elementsKey: "_elements"
}

? 3. 調(diào)用轉(zhuǎn)換函數(shù),打印結(jié)果。

let conv = new convertxml.ConvertXML();
let result = conv.convertToJSObject(xml, options);
let strRes = JSON.stringify(result); // 將js對象轉(zhuǎn)換為json字符串,用于顯式輸出
console.info(strRes);
// 也可以直接處理轉(zhuǎn)換后的JS對象,獲取標簽值
let title = result['_elements'][0]['_elements'][0]['_elements'][0]['_text']; // 解析標簽對應的值
let todo = result['_elements'][0]['_elements'][1]['_elements'][0]['_text']; // 解析標簽對應的值
let todo2 = result['_elements'][0]['_elements'][2]['_elements'][0]['_text']; // 解析標簽對應的值
console.info(title); // Happy
console.info(todo); // Work
console.info(todo2); // Play

輸出結(jié)果如下所示:

strRes:
{"_declaration":{"_attributes":{"version":"1.0","encoding":"utf-8"}},"_elements":[{"_type":"element","_name":"note",
 "_attributes":{"importance":"high","logged":"true"},"_elements":[{"_type":"element","_name":"title",
 "_elements":[{"_type":"text","_text":"Happy"}]},{"_type":"element","_name":"todo",
 "_elements":[{"_type":"text","_text":"Work"}]},{"_type":"element","_name":"todo",
 "_elements":[{"_type":"text","_text":"Play"}]}]}]}
title:Happy
todo:Work
todo2:Play

審核編輯 黃宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • XML
    XML
    +關(guān)注

    關(guān)注

    0

    文章

    187

    瀏覽量

    33022
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1966

    瀏覽量

    29962
收藏 人收藏

    評論

    相關(guān)推薦

    XML HarmonyOS 生成,解析轉(zhuǎn)換(上)

    一、XML 概述 XML(可擴展標記語言)是一種用于描述數(shù)據(jù)的標記語言,旨在提供一種通用的方式來傳輸和存儲數(shù)據(jù),特別是 Web 應用程序中經(jīng)常使用的數(shù)據(jù)。XML 并不預定義標記。因此,XML
    的頭像 發(fā)表于 02-18 09:35 ?620次閱讀

    OpenHarmony語言基礎(chǔ)類庫【@ohos.xml (xml解析生成)】

    XML文本轉(zhuǎn)換為JavaScript對象、以及XML文件生成解析的一系列接口。
    的頭像 發(fā)表于 05-08 17:05 ?763次閱讀

    跪求大神--XML解析

    小弟近日做一案子,需要用到UDP通訊,內(nèi)容以XML格式發(fā)送接收。通訊沒有問題,現(xiàn)在的難題是如何把接收到的XML信息直接解析出來,提取想要的字符串內(nèi)容。NI里面有例子都是讀取文檔的,想問各路大神有沒有辦法直接從
    發(fā)表于 06-04 10:22

    XML解析轉(zhuǎn)樹形控件

    xml解析成樹形控件執(zhí)行速度奇慢代碼見附件版本8.6以上求提高效率的辦法
    發(fā)表于 10-17 14:59

    如何生成xml文件

    如何用Labview生成這樣的XML文件?
    發(fā)表于 01-13 15:29

    DevEco Studio將SVG文件轉(zhuǎn)換XML文件的過程分享

    》Svg To Xml?!   ?、選擇需要轉(zhuǎn)換的svg文件,并命名,點擊OK按鈕開始轉(zhuǎn)換。    3、轉(zhuǎn)換成功后,可以resources
    發(fā)表于 05-06 11:23

    【中秋國慶不斷更】XMLHarmonyOS生成,解析轉(zhuǎn)換(上)

    。 XML還支持命名空間、實體引用、注釋、處理指令等特性,使其能夠靈活地適應各種數(shù)據(jù)需求。 語言基礎(chǔ)類庫提供了XML相關(guān)的基礎(chǔ)能力,包括:??XML生成??、??
    發(fā)表于 09-27 15:21

    【中秋國慶不斷更】XMLHarmonyOS生成解析轉(zhuǎn)換

    一、XML解析 對于以XML作為載體傳遞的數(shù)據(jù),實際使用需要對相關(guān)的節(jié)點進行解析,一般包括??解析
    發(fā)表于 09-27 15:24

    HarmonyOS語言基礎(chǔ)類庫開發(fā)指南上線啦!

    指南中提供了詳細的介紹和開發(fā)指導,幫助開發(fā)者全面了解并發(fā)實現(xiàn)、容器類庫基礎(chǔ)操作、XML生成解析轉(zhuǎn)換等。 本期HarmonyOS開發(fā)者資料
    發(fā)表于 10-18 16:36

    報文解析工具XML數(shù)據(jù)字典

    針對報文解析過程存在的數(shù)據(jù)存儲無序、查詢和調(diào)用不便等問題,提出應用XML 數(shù)據(jù)字典進行數(shù)據(jù)存儲的方案。根據(jù)給定的數(shù)據(jù)表,設(shè)計XML 形式的數(shù)據(jù)字典。實現(xiàn)
    發(fā)表于 03-28 09:38 ?36次下載

    MTK自帶的XML解析

    現(xiàn)在大多數(shù)軟件都用xml作為配置文件,MTK本身也帶了XML文件的解析,在此我不評說自帶XML解析效率
    發(fā)表于 08-31 16:00 ?0次下載

    MAVLink學習之路03 _XML定義MSG并生成C代碼

    MAVLink學習之路03_XML定義MSG并生成C代碼
    的頭像 發(fā)表于 03-07 16:46 ?3550次閱讀

    異構(gòu)文本數(shù)據(jù)轉(zhuǎn)換過程中解析XML文本的方法對比

    對異構(gòu)文本數(shù)據(jù)轉(zhuǎn)換過程中解析XML文本的DOM、SAX、JOM4J方法進行對比研究,以解析時間、內(nèi)存堆占用空間、CPU占用率為評價指標來判定4種解析
    發(fā)表于 03-25 11:12 ?9次下載
    異構(gòu)文本數(shù)據(jù)<b class='flag-5'>轉(zhuǎn)換過程中</b><b class='flag-5'>解析</b><b class='flag-5'>XML</b>文本的方法對比

    HarmonyOS語言基礎(chǔ)類庫開發(fā)指南上線啦!

    指南中提供了詳細的介紹和開發(fā)指導,幫助開發(fā)者全面了解并發(fā)實現(xiàn)、容器類庫基礎(chǔ)操作、XML生成解析轉(zhuǎn)換等。 本期HarmonyOS開發(fā)者資料
    的頭像 發(fā)表于 10-18 16:20 ?531次閱讀
    <b class='flag-5'>HarmonyOS</b>語言基礎(chǔ)類庫開發(fā)指南上線啦!

    【JAVA UI】【HarmonyOS】【Demo】 鴻蒙如何進行 xml 解析

    【鴻蒙】鴻蒙如何進行數(shù)據(jù)解析 【問題描述】有時候我們從服務(wù)器獲取是 xml 格式數(shù)據(jù),我們需要將 xml 轉(zhuǎn)化成 model 對象,該如何使用呢?下面舉個例子說明一,將分以下幾步進行
    的頭像 發(fā)表于 02-19 15:59 ?487次閱讀
    【JAVA UI】【<b class='flag-5'>HarmonyOS</b>】【Demo】 鴻蒙如何進行 <b class='flag-5'>xml</b> <b class='flag-5'>解析</b>