9

我有一些代码可以下载 gzipped 文件并解压缩它们。问题是,我无法让它解压缩整个文件,它只读取前 4096 个字节,然后再读取大约 500 个字节。

Byte[] buffer = new Byte[4096];
int count = 0;
FileStream fileInput = new FileStream("input.gzip", FileMode.Open, FileAccess.Read, FileShare.Read);
FileStream fileOutput = new FileStream("output.dat", FileMode.Create, FileAccess.Write, FileShare.None);
GZipStream gzipStream = new GZipStream(fileInput, CompressionMode.Decompress, true);

// Read from gzip steam
while ((count = gzipStream.Read(buffer, 0, buffer.Length)) > 0)
{
    // Write to output file
    fileOutput.Write(buffer, 0, count);
}

// Close the streams
...

我检查了下载的文件;压缩后为 13MB,包含一个 XML 文件。我已经手动解压了 XML 文件,内容就在那里。但是当我使用这段代码执行此操作时,它只输出 XML 文件的开头。

任何人都知道为什么会发生这种情况?

4

4 回答 4

4

编辑

尽量不要让 GZipStream 打开:

GZipStream gzipStream = new GZipStream(fileInput, CompressionMode.Decompress,  
                                                                         false);

或者

GZipStream gzipStream = new GZipStream(fileInput, CompressionMode.Decompress);
于 2010-06-18T09:23:26.217 回答
1

我最终使用 gzip 可执行文件而不是 GZipStream 来进行解压缩。由于某种原因,它无法处理该文件,但可执行文件可以。

于 2010-06-18T12:06:59.160 回答
1

同样的事情发生在我身上。在我的情况下,最多只能读取 6 行,然后到达文件末尾。于是我意识到虽然扩展名是gz,但它是由GZipStream不支持的另一种算法压缩的。所以我使用了 SevenZipSharp库,它工作正常。这是我的代码

您可以使用 SevenZipSharp 库

using (var input = File.OpenRead(lstFiles[0]))
{
    using (var ds = new SevenZipExtractor(input))
    {
        //ds.ExtractionFinished += DsOnExtractionFinished;

        var mem = new MemoryStream();
        ds.ExtractFile(0, mem);

        using (var sr = new StreamReader(mem))
        {
            var iCount = 0;
            String line;
            mem.Position = 0;
            while ((line = sr.ReadLine()) != null && iCount < 100)
            {
                iCount++;
                LstOutput.Items.Add(line);
            }

        }
    }
} 
于 2013-10-03T20:36:11.303 回答
0

你打电话Close还是FlushfileOutput?(或者只是将其包装在 中using,这是推荐的做法。)如果您不这样做,则程序结束时可能不会将文件刷新到磁盘。

于 2010-06-18T09:45:14.330 回答