如何从pdf中删除分页符,因此输出将是单个“页面”PDF?因此,如果正常页面是400x900并且我有4页,则生成的文件将是1600x900。我之前为Tif文件(Remove page breaks in multi-page tif to make one long page)做了这个,但是想用PDF做。我可以转换为ps,删除任何代码意味着'分页符',然后转换回pdf?
答案 0 :(得分:4)
这可以通过使用单个圆柱形PdfTable在iTextSharp库中完成,并根据页数动态更改文档大小。
您当然需要对发现的here
的iTextSharp DLL进行一些引用using iTextSharp.text;
using iTextSharp.text.pdf;
using System.IO;
这是一个简单的例子:
public static void MergePages()
{
using (PdfReader reader = new PdfReader(@"C:\Users\cmilne\Desktop\AA0081913.pdf"))//Original PDF containing page breaks.
{
int pages = reader.NumberOfPages;
float postProcessPageHeight = 0;
float postProcessPageWidth = 0;
for (int p = 1; p <= bill.PageCount; p++)
{
var size = bill.PdfReader.GetPageSize(p);
postProcessPageHeight += (size.Height);
if (size.Width > postProcessPageWidth)
postProcessPageWidth = (size.Width);
}
var rect = new Rectangle(postProcessPageWidth, postProcessPageHeight);
using (Document document = new Document(rect, 0, 0, 0, 0))
{
PdfWriter writer = PdfWriter.GetInstance(document, new FileStream(@"C:\Users\cmilne\Desktop\AA0081913_NEW.pdf", FileMode.Create)); //Declare location\name of new PDF not containing page breaks.
document.Open();
PdfImportedPage page;
PdfPTable table = new PdfPTable(1);
table.WidthPercentage = 100;
for (int i = 1; i <= pages; i++)
{
page = writer.GetImportedPage(reader, i);
table.AddCell(iTextSharp.text.Image.GetInstance(page));
}
document.Add(table);
document.Close();
}
}
}
结束页面大小必须小于14400 x 14400.(这就是iTextSharp所允许的)一个普通分辨率的8 1/2 x 11 PDF最多可以显示18页。
答案 1 :(得分:1)
使用iTextSharp C#库。它为您提供了许多操作PDF的选项。之前我必须为闭源文档存储库编写导入应用程序时使用过它。它就像一个魅力。唯一的缺点是他们的文档有点不稳定,因为他们希望你购买他们的书。您可以免费浏览他们的Java API,因为它几乎与C#完全相同,只需使用它来查找C#版本。
iText:http://itextpdf.com/