在Java中阅读inputstream的第一部分

时间:2011-04-07 09:02:32

标签: java file

我有一个从URLConnection读取的XML文件。文件随着时间的推移而增长。我想读取文件的前100k,今天文件是1.3MB。然后我想解析我读过的部分。 我怎么能这样做?

2 个答案:

答案 0 :(得分:3)

(从头开始)

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);

答案 1 :(得分:1)

据我了解,您不仅对100k的流感兴趣,而且对100k的流感兴趣,您可以从中提取所需的数据。这意味着按照Peter的建议采用100k不会起作用,因为它可能会导致XML格式不正确。

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

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

正如你刚才提到的那样,Android doesn't have可以使用StAX解析器。但它具有XmlPullParser具有类似功能。