我尝试使用此代码:
public void Extract(string SourceFile, string password)
{
SevenZipExtractor szip = new SevenZipExtractor(SourceFile, password);
foreach (DataGridViewRow row in DGVFile.Rows)
{
string NameFile = (string)row.Cells[0].Value;
int indexZip = szip.ArchiveFileData.IndexOf(NameFile);
Stream pathDirectory = @"C:\";
szip.ExtractFile(indexZip, pathDirectory);
}
}
但这是错误,在第 7 行和第 8 行。也许任何人都可以解释如何使用在我的datagridview中选择的名称以及变量pathDirectory中文件流的用途来获取我的存档中的索引文件。谢谢
编辑:我使用DataGridView DGVDekripsi,所以我替换了它。这个正确的代码,它有效。
public void Extract(string SourceFile, string password)
{
string OutputLocation = txtOutputDe.Text;
SevenZipExtractor szip = new SevenZipExtractor(SourceFile, password);
foreach (DataGridViewRow row in DGVDekripsi.Rows)
{
string NameFile = (string)row.Cells[1].Value;
FileStream fs = File.OpenWrite(Path.Combine(OutputLocation, NameFile));
szip.ExtractFile(NameFile, fs );
}
return;
}
第 8 行(确保using System.IO;
):
FileStream fs = File.OpenWrite(Path.Combine(@"c:", NameFile));
szip.ExtractFile(indexZip, fs);
确保您有权写入磁盘 C,或更改临时文件夹的路径。
IndexOf() 对我不起作用...我喜欢这个解决方案:
using (SevenZipExtractor zip = new SevenZipExtractor(zipFile))
{
int indexZip = zip.ArchiveFileData.First(archiveFileInfo =>
archiveFileInfo.FileName.Equals("MyFile.xml")).Index;
using (FileStream fs = File.OpenWrite(tempFile))
{
zip.ExtractFile(indexZip, fs);
}
}