写入CSV文件,然后在Appengine(Java)中将其压缩

时间:2011-02-26 18:36:32

标签: java google-app-engine csv export

我目前正在研究一个用Java做的项目,谷歌上的appengine。

Appengine不允许存储文件,因此无法使用任何磁盘表示对象。其中一些包括File类。

我想写数据并将其导出到几个csv文件,然后将其压缩,并允许用户下载。

如果不使用任何文件类,我怎么能这样做?我在文件处理方面不是很有经验,所以我希望你们能告诉我。

感谢。

2 个答案:

答案 0 :(得分:9)

您可以创建一个zip文件,并在用户下载时添加到该文件中。如果您使用的是servlet,那么这是一个很好的方法:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    // ..... process request

    // ..... then respond
    response.setContentType("application/zip");
    response.setStatus(HttpServletResponse.SC_OK);

    // note : intentionally no content-length set, automatic chunked transfer if stream is larger than the internal buffer of the response
    ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream());

    byte[] buffer = new byte[1024 * 32];
    try {
            // case1: already have input stream, typically ByteArrayInputStream from a byte[] full of previoiusly prepared csv data

            InputStream in = new BufferedInputStream(getMyFirstInputStream());
            try {
                zipOut.putNextEntry(new ZipEntry("FirstName"));

                int length;
                while((length = in.read(buffer)) != -1) {
                    zipOut.write(buffer, 0, length);
                }

                zipOut.closeEntry();
            } finally {
                in.close();
            }

            // case 2: write directly to output stream, i.e. you have your raw data but need to create csv representation

            zipOut.putNextEntry(new ZipEntry("SecondName"));

            // example setup, key is to use the below outputstream 'zipOut' write methods
            Object mySerializer = new MySerializer(); // i.e. csv-writer
            Object myData = getMyData(); // the data to be processed by the serializer in order to make a csv file

            mySerizalier.setOutput(zipOut);

            // write whatever you have to the zipOut
            mySerializer.write(myData);

            zipOut.closeEntry();

            // repeat for the next file.. or make for-loop

        }
    } finally { 
        zipOut.close();
    }
}

除非您有内存限制,否则没有理由将数据存储在文件中。文件为您提供InputStream和OutputStream,两者都具有内存中的等价物。

请注意,创建csv编写器通常意味着执行this之类的操作,其中的重点是获取一段数据(数组列表或映射,无论您拥有什么)并将其转换为byte []部分。使用DataOutputStream等工具将byte []部分附加到OutputStream中(如果愿意,可以自己创建)或OutputStreamWriter。

答案 1 :(得分:3)

如果您的数据不是很大,意味着可以保留在内存中,然后导出到CSV并压缩和流式传输以供下载,这些都可以随时进行。缓存可以在任何这些步骤中完成,这在很大程度上取决于应用程序的业务逻辑。