我有一些代码可以下载gzip压缩文件并对其进行解压缩。问题是,我无法解压缩整个文件,它只读取前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文件的最开头。
任何人都有任何想法可能会发生这种情况?
答案 0 :(得分:4)
修改强>
尽量不要打开GZipStream:
GZipStream gzipStream = new GZipStream(fileInput, CompressionMode.Decompress,
false);
或
GZipStream gzipStream = new GZipStream(fileInput, CompressionMode.Decompress);
答案 1 :(得分:1)
我最终使用gzip可执行文件来进行解压缩而不是GZipStream。它由于某种原因无法处理文件,但可执行文件可以。
答案 2 :(得分: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);
}
}
}
}
答案 3 :(得分:0)
您是否在Close
上致电Flush
或fileOutput
? (或者只是将其包装在using
中,这是推荐的做法。)如果不这样做,程序结束时文件可能不会刷新到磁盘。