안드로이드 색소폰 구문 분석 XML 방법
下面说明第一种解析sax解析方式:
SAX是一个解析速度快并且占用内存少的xml解析器,非常适合用于Android等移动设备。 SAX解析XML文件采用的是事件驱动,也就是说,它并不需要解析完整个文档,在按内容顺序解析文档的过程中,SAX会判断当前读到的字符是否合法XML语法中的某部分,如果符合就会触发事件。所谓事件,其实就是一些回调(callback)方法,这些方法(事件)定义在ContentHandler接口。下面是一些ContentHandler接口常用的方法:
startDocument() 当遇到文档的开头的时候,调用这个方法,可以在其中做一些预处理的工作。
endDocument() 和上面的方法相对应,当文档结束的时候,调用这个方法,可以在其中做一些善后的工作。
startElement(String namespaceURI, String localName, String qName, Attributes atts)
当读到一个开始标签的时候,会触发这个方法。namespaceURI就是命名空间,localName是不带命名空间前缀的标签名,qName是带命名空间前缀的标签名。通过atts可以得到所有的属性名和相应的值。要注意的是SAX中一个重要的特点就是它的流式处理,当遇到一个标签的时候,它并不会纪录下以前所碰到的标签,也就是说,在startElement()方法中,所有你所知道的信息,就是标签的名字和属性,至于标签的嵌套结构,上层标签的名字,是否有子元属等等其它与结构相关的信息,都是不得而知的,都需要你的程序来完成。这使得SAX在编程处理上没有DOM来得那么方便。
endElement(String uri, String localName, String name) 这个方法和上面的方法相对应,在遇到结束标签的时候,调用这个方法。 characters(char[] ch, int start, int length)
这个方法用来处理在XML文件中读到的内容,第一个参数为文件的字符串内容,后面两个参数是读到的字符串在这个数组中的起始位置和长度,使用new String(ch,start,length)就可以获取内容。
xml的源文件和android dom 解析xml方式中的xml 文件内容相同,可以参照那个文件来解析,只是名称不同而已,
这个途中图中有三个saxTest.xml文件,分别对应三种不同的读取方式
<pre name="code" class="html"> // 读取类得包下的xml文件 // InputStream inputStream = // this.getClass().getClassLoader().getResourceAsStream("cn/com/sax/saxTest.xml"); //读取src下xml文件 InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("saxTest.xml"); // 读取assets下的xml文件 // InputStream inputStream = this.getAssets().open("saxTest.xml");
下面放出我解析的源码:
/** * 用sax解析xml的第一种方式 * @return */ private String saxParse(){ SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parser; String xmlStr = "第一种解析方式:\n"; try { // 读取类得包下的xml文件 // InputStream inputStream = // this.getClass().getClassLoader().getResourceAsStream("cn/com/sax/saxTest.xml"); //读取src下xml文件 InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("saxTest.xml"); // 读取assets下的xml文件 // InputStream inputStream = this.getAssets().open("saxTest.xml"); parser = factory.newSAXParser(); SaxParseHandler personHandler = new SaxParseHandler(); parser.parse(inputStream, personHandler); xmlStr = xmlStr + personHandler.parseToString(); } catch (ParserConfigurationException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } catch (SAXException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } catch (IOException e) { e.printStackTrace(); Log.e("TEST", "" + e.toString()); } return xmlStr; }
继承DefaultHandler处理xml中的元素节点。
<span style="font-size:13px;">class SaxParseHandler extends DefaultHandler { String result; public String parseToString() { return result; } String str = null; /** * xml开始时,执行此函数 */ @Override public void startDocument() throws SAXException { // Log.e("TEST", "startDocument"); } /** * xml结束时,执行此函数 */ @Override public void endDocument() throws SAXException { // Log.e("TEST", "endDocument"); } /** * xml标签开始时,执行此函数,读取标签名称,和标签内的属性 */ @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if ("group".equals(localName)) { String groupName = attributes.getValue(0); String num = attributes.getValue(1); result = result + "groupName=" + groupName + " num =" + num + "\n"; } else if ("person".equals(localName)) { String personName = attributes.getValue(0); String age = attributes.getValue(1); // 和getValue(1)等效 // String txt = attributes.getValue("age"); result = result + "personName" + personName + " age=" + age + "\n"; } else { str = localName; } // Log.e("TEST", "startElement"); } /** * xml标签结束时,执行此函数 */ @Override public void endElement(String uri, String localName, String qName) throws SAXException { str = null; // Log.e("TEST", "endElement"); } /** * 解析标签内的值,如<chinese>ssss</chinese>,为了读取"ssss" */ @Override public void characters(char[] ch, int start, int length) throws SAXException { if (str != null) { String data = new String(ch, start, length); //xml文件格式化的时候容易产生以下换行,制表符等特殊字符, //这些需要特别注意处理 Pattern p = Pattern.compile("\\s*|\t|\r|\n"); Matcher m = p.matcher(data); data = m.replaceAll(""); if ("chinese".equals(str)) { if(!data.equals("")){ String chinese = data; result = result + "chinese=" + chinese; } } else if ("english".equals(str)) { if(!data.equals("")){ String english = data; result = result + "english=" + english + "\n"; } } } } }</span>
以上就是 android sax解析 xml方式的内容,更多相关内容请关注PHP中文网(www.php.cn)!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











최근 아이스 유니버스는 삼성의 차기 플래그십 스마트폰으로 널리 알려진 갤럭시 S25 울트라에 대한 세부 정보를 꾸준히 공개해 왔습니다. 무엇보다도 유출자는 삼성이 카메라 업그레이드를 하나만 가져올 계획이라고 주장했습니다.

OnLeaks는 이제 Android Headlines와 제휴하여 X(이전 Twitter) 팔로어로부터 4,000달러 이상의 수익을 창출하려는 시도가 실패한 지 며칠 후 Galaxy S25 Ultra에 대한 첫 번째 모습을 제공합니다. 맥락에 따라 h 아래에 포함된 렌더링 이미지

TCL은 두 가지 새로운 스마트폰을 발표하는 것과 함께 NXTPAPER 14라는 새로운 Android 태블릿도 발표했는데, TCL의 거대한 화면 크기는 판매 포인트 중 하나입니다. NXTPAPER 14는 TCL의 시그니처 브랜드인 무광택 LCD 패널 버전 3.0을 갖추고 있습니다.

삼성전자는 팬에디션(FE) 스마트폰 시리즈를 언제 업데이트할지 아직 힌트를 주지 않았다. 현재 상태로 Galaxy S23 FE는 2023년 10월 초에 출시된 회사의 최신 버전으로 남아 있습니다.

Vivo Y300 Pro는 방금 완전히 공개되었으며 대용량 배터리를 갖춘 가장 얇은 중급 Android 휴대폰 중 하나입니다. 정확히 말하면 스마트폰의 두께는 7.69mm에 불과하지만 배터리 용량은 6,500mAh입니다. 최근 출시된 것과 동일한 용량이다.

최근 아이스 유니버스는 삼성의 차기 플래그십 스마트폰으로 널리 알려진 갤럭시 S25 울트라에 대한 세부 정보를 꾸준히 공개해 왔습니다. 무엇보다도 유출자는 삼성이 카메라 업그레이드를 하나만 가져올 계획이라고 주장했습니다.

Redmi Note 14 Pro Plus는 이제 작년 Redmi Note 13 Pro Plus(Amazon에서 현재 $375)의 직접적인 후속 제품으로 공식화되었습니다. 예상대로 Redmi Note 14 Pro Plus는 Redmi Note 14 및 Redmi Note 14 Pro와 함께 Redmi Note 14 시리즈를 주도합니다. 리

OnePlus의 자매 브랜드 iQOO는 2023-4년 제품 주기가 거의 끝날 수 있습니다. 그럼에도 불구하고 브랜드는 Z9 시리즈가 아직 끝나지 않았다고 선언했습니다. 최종이자 아마도 최고급인 Turbo+ 변형이 예상대로 발표되었습니다. 티
