繁体   English   中英

阅读Java输入流的第一部分

[英]Read first part of inputstream in Java

我有一个从URLConnection读取的XML文件。 该文件随着时间的流逝而增长。 我想读取文件的前100k,今天文件为1.3MB。 然后,我想解析我已阅读的部分。 我怎样才能做到这一点?

(从头开始)

int length = 100*1024;
byte[] buf = new byte[length];
urlConnection.getInputStream().read(buf,0,length);
StringBufferInputStream in = new StringBufferInputStream(new String(buf));
new SAXParser().parse(in,myHandler);

据我了解,您不仅对100k的流感兴趣,还对100k的流感兴趣,可以从中提取所需的数据。 这意味着彼得提出的100k无效,因为这可能会导致XML格式不正确。

相反,我建议使用StAX解析器,它使您能够直接从流中读取和解析XML,并能够在达到100k(或接近)限制时停止。

有关更多信息,请查看XMLStreamReader接口(及其用法示例)。 例如,您可以循环播放直到名称为“ result”的START_ELEMENT ,然后使用方法getTextCharacters(int sourceStart, char[] target, int targetStart, int length)指定100k作为缓冲区大小。

如您所提到的,Android当前没有 StAX解析器。 但是,它确实具有具有类似功能的XmlPullParser

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM