我已经搜索了这个问题的答案。我知道为什么我收到异常,但我不能在我的代码中找到它的原因。C#PDF删除 - 正在被另一个进程使用的文件'
基本上,我的代码创建四个独立的PDF文件,将它们加入到大PDF文件中,然后删除原来的四个文件。一切都很好,除非我在尝试删除文件时收到IOException,因为它们正在被另一个进程使用。
下面是我用合并文件的代码:
private static Document MergeFiles(string[] fileNames, string finalFileName)
{
Document doc = new Document(PageSize.A4, 20, 20, 25, 25);
if (fileNames.Length > 0)
{
int a = 0;
PdfReader reader = new PdfReader(fileNames[a]);
int n = reader.NumberOfPages;
FileStream output = new FileStream("C:\\temp\\" + finalFileName, FileMode.Create);
PdfWriter writer = PdfWriter.GetInstance(doc, output);
doc.Open();
PdfContentByte cb = writer.DirectContent;
PdfImportedPage page;
int rotation;
while (a < fileNames.Length)
{
int i = 0;
while (i < n)
{
i++;
doc.SetPageSize(reader.GetPageSizeWithRotation(i));
doc.NewPage();
page = writer.GetImportedPage(reader, i);
rotation = reader.GetPageRotation(i);
if (rotation == 90 || rotation == 270)
cb.AddTemplate(page, 0, -1f, 1f, 0, 0, reader.GetPageSizeWithRotation(i).Height);
else
cb.AddTemplate(page, 1f, 0, 0, 1f, 0, 0);
}
a++;
if (a < fileNames.Length)
{
reader = new PdfReader(fileNames[a]);
n = reader.NumberOfPages;
}
}
}
doc.Close();
return doc;
}
这里是代码删除文件:
private static void DeleteFile(string[] fileNames)
{
if (fileNames != null)
{
for (int x = 0; x < fileNames.Length; x++)
{
if(!fileNames[x].Equals(""))
System.IO.File.Delete(fileNames[x]);
}
}
}
任何援助将不胜感激。当我合并文档时,我假定在某个循环的某个地方,某些东西没有被关闭(读写器),但我尝试了很多不同的组合,没有任何东西可以工作。这真的开始让我烦恼。
UPDATE 感谢您的意见,每个人。我已经修改了我的代码如下:
private static Document MergeFiles(string[] fileNames, string finalFileName)
{
Document doc = new Document(PageSize.A4, 20, 20, 25, 25);
if (fileNames.Length > 0)
{
while (a < fileNames.Length)
{
using (PdfReader reader = new PdfReader(fileNames[a]))
using (FileStream output = new FileStream("C:\\temp\\" + finalFileName, FileMode.Create))
using (PdfWriter writer = PdfWriter.GetInstance(doc, output))
{
int n = reader.NumberOfPages;
doc.Open();
PdfContentByte cb = writer.DirectContent;
PdfImportedPage page;
int rotation;
int i = 0;
while (i < n)
{
i++;
doc.SetPageSize(reader.GetPageSizeWithRotation(i));
doc.NewPage();
page = writer.GetImportedPage(reader, i);
rotation = reader.GetPageRotation(i);
if (rotation == 90 || rotation == 270)
cb.AddTemplate(page, 0, -1f, 1f, 0, 0, reader.GetPageSizeWithRotation(i).Height);
else
cb.AddTemplate(page, 1f, 0, 0, 1f, 0, 0);
}
a++;
if (a < fileNames.Length)
{
n = reader.NumberOfPages;
}
}
}
}
doc.Close();
return doc;
}
它编译,但我会在运行时错误指向到使用循环的结束括号:虽然您要关闭
System.ObjectDisposedException was unhandled
Message=Cannot access a closed file.
也许在using语句中实例化PdfReader(fileName [a])? – 2013-03-23 17:08:30
有几点建议:不要返回一个'Document'对象,一旦关闭它就没有意义了。或者返回一个成功的布尔值,文件名(可能不是因为你将它传入)或者可能切换到一个'MemoryStream'并返回字节数组。如果你原来的四个文档足够小,我也可以创建一个'MemoryStream',然后从字节数组中取出。这样你就不必担心有时会碰到磁盘。 – 2013-03-24 15:23:41
Chris,我结束了你的解决方案,并使用MemorySteam和字节数组。它最终变得更快更容易,没有任何与PdfReaders等相关的问题。 感谢您的建议! – 2013-03-25 06:22:46