亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Java 使用 SAX 解析讀取 XML

Java 使用 SAX 解析讀取 XML

慕桂英4014372 2023-08-16 17:39:42
所以我開始使用 xml 和 SAX 解析器,現在我試圖弄清楚它是如何工作的,我熟悉 JSON,但這似乎不像 JSON 那樣工作。所以這是我正在使用的代碼package com.myalbion.gamedataextractor.handlers;import java.io.File;import java.io.IOException;import java.util.List;import java.util.Map;import javax.xml.parsers.ParserConfigurationException;import javax.xml.parsers.SAXParser;import javax.xml.parsers.SAXParserFactory;import org.xml.sax.Attributes;import org.xml.sax.SAXException;import org.xml.sax.helpers.DefaultHandler;import com.myalbion.gamedataextractor.Main;import com.myalbion.gamedataextractor.datatables.Language;import com.myalbion.gamedataextractor.datatables.Localized;import com.myalbion.gamedataextractor.datatables.XMLFile;public class LocalizationXMLFileHandler extends DefaultHandler {    private String temp;    Localized localized;    List<Localized> localizedList;    Map<Language, String> tempMap;    /*     * When the parser encounters plain text (not XML elements),     * it calls(this method, which accumulates them in a string buffer     */    public void characters(char[] buffer, int start, int length) {           temp = new String(buffer, start, length);    }    /*     * Every time the parser encounters the beginning of a new element,     * it calls this method, which resets the string buffer     */     public void startElement(String uri, String localName,                  String qName, Attributes attributes) throws SAXException {           temp = "";           if (qName.equalsIgnoreCase("tu")) {               localized = new Localized();               localized.setUniqueName(attributes.getValue("tuid"));           } else if(qName.equalsIgnoreCase("tuv")) {               tempMap.put(Language.getLanguageFromCode(attributes.getValue("xml:lang")), )           }    }    } }我正在嘗試將此 xml 文件中的數據提取到包含語言枚舉和本地化名稱的 tempMap 中。
查看完整描述

1 回答

?
精慕HU

TA貢獻1845條經驗 獲得超8個贊

每次點擊新的文本節點(包括僅包含空格的文本節點,例如 和 之間的文本節點)時,您都會覆蓋文本</seg>緩沖區</tuv>。處理結束標簽時需要保存文本緩沖區的內容,處理結束標簽seg時將其拾取。tuv

您還應該注意,單個文本節點的內容可以通過對 text() 的一系列調用來提供:解析器可以以任何它喜歡的方式分解它(許多解析器在實體邊界上執行此操作)。您需要通過附加到緩沖區來累積內容。

另請注意,XML 區分大小寫;在測試元素名稱時,您不應該真正忽略大小寫。

查看完整回答
反對 回復 2023-08-16
  • 1 回答
  • 0 關注
  • 111 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號