我正在尝试使用PDFSharp读取PDF文档中所有注释的内容,同时跟踪它们所在的页面。我正在尝试检索的“内容”位于PdfItem的“结果视图”中,其中显示“扩展结果视图将枚举IEnumerable”
我正在使用以下代码:
private void LoadCommentList(string file) //using pdfsharp
{
PdfSharp.Pdf.PdfDocument inputDoc = PdfSharp.Pdf.IO.PdfReader.Open(file, PdfDocumentOpenMode.Import);
PdfSharp.Pdf.PdfDocument document = new PdfSharp.Pdf.PdfDocument();
PdfSharp.Pdf.PdfPage page = new PdfSharp.Pdf.PdfPage();
for (int i = 0; i < inputDoc.PageCount; i++)
{
page = inputDoc.Pages[i];
page = document.AddPage(page);
for (int p = 0; p < document.Pages[i].Annotations.Elements.Count; p++)
{
PdfItem textAnnot = document.Pages[i].Annotations.Elements.GetObject(p);
//add specific item in "Results View" to CommentList here......
}
}
}
如何以编程方式阅读“结果视图”,以便获取PDF注释的内容?
感谢您的帮助。
答案 0 :(得分:1)
原来比我尝试的方法更容易实现这一目标。而不是使用Pdfitem对象而是使用PdfAnnotation对象。应该从一开始就这样做。代码示例如下:
private void LoadCommentList(string file) //using pdfsharp
{
PdfSharp.Pdf.PdfDocument inputDoc = PdfSharp.Pdf.IO.PdfReader.Open(file, PdfDocumentOpenMode.Import);
PdfSharp.Pdf.PdfDocument document = new PdfSharp.Pdf.PdfDocument();
PdfSharp.Pdf.PdfPage page = new PdfSharp.Pdf.PdfPage();
for (int i = 0; i < inputDoc.PageCount; i++)
{
page = inputDoc.Pages[i];
page = document.AddPage(page);
for (int p = 0; p < document.Pages[i].Annotations.Elements.Count; p++)
{
PdfAnnotation textAnnot = document.Pages[i].Annotations[p];
string content = textAnnot.Contents;
if (content != null)
{
CommentList.Add(content);
}
}
}
}