如何获取和设置注释 PDF itext c# 的 /BSIColumnData 的值
How to get and set value for /BSIColumnData of an annotation PDF itext c#
如何使用 itext c# 作为附件获取和设置 PDF 注释(标记)的 /BSIColumnData 的值?
我在下面使用 Itext7 代码,但它在 BSIColumnData:
处出错
public void BSIcontents ()
{
string pdfPath = @"C:\test PDF.pdf";
iText.Kernel.Pdf.PdfReader pdfReader = new iText.Kernel.Pdf.PdfReader(pdfPath);
iText.Kernel.Pdf.PdfDocument pdfDoc = new iText.Kernel.Pdf.PdfDocument(pdfReader);
int numberOfPages = pdfDoc.GetNumberOfPages();
int z = 0;
for (int i = 1; i <= numberOfPages; i++)
{
iText.Kernel.Pdf.PdfDictionary page = pdfDoc.GetPage(i).GetPdfObject();
iText.Kernel.Pdf.PdfArray annotArray = page.GetAsArray(iText.Kernel.Pdf.PdfName.Annots);
if (annotArray == null)
{
z++;
continue;
}
int size = annotArray.Size();
for (int x = 0; x < size; x++)
{
iText.Kernel.Pdf.PdfDictionary curAnnot = annotArray.GetAsDictionary(x);
if (curAnnot != null)
{
if (curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData) != null)
{
MessageBox.Show("BSIColumnData: " + curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData).ToString());
}
}
}
}
pdfReader.Close();
}
在Bluebeam Revu中,您可以看到如下:
在itext-rups 5.5.9中,您可以看到如下:
我看到两个错误:
您尝试像这样使用 BSIColumnData 名称:
iText.Kernel.Pdf.PdfName.BSIColumnData
这假设您的自定义名称已经有一个静态 PdfName
成员。但是当然没有,只有 itext 本身使用的标准名称的预定义成员。如果你想使用其他名称,你必须自己创建一个 PdfName
实例并使用该实例,例如像这样
var BSIColumnData = new iText.Kernel.Pdf.PdfName("BSIColumnData");
您尝试检索该名称的值作为字符串
curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData)
但从您的 RUPS 屏幕截图可以清楚地看出,该名称的值是一个字符串数组。因此,即使按照第一项 GetAsString(BSIColumnData)
中所述进行更正后,也会 return null
。相反做
var BSIColumnData = new iText.Kernel.Pdf.PdfName("BSIColumnData");
var array = curAnnot.GetAsArray(BSIColumnData);
选中 if (array != null)
后,您现在可以使用 array.GetAsString(index)
.
访问各自索引处的字符串
如何使用 itext c# 作为附件获取和设置 PDF 注释(标记)的 /BSIColumnData 的值? 我在下面使用 Itext7 代码,但它在 BSIColumnData:
处出错public void BSIcontents ()
{
string pdfPath = @"C:\test PDF.pdf";
iText.Kernel.Pdf.PdfReader pdfReader = new iText.Kernel.Pdf.PdfReader(pdfPath);
iText.Kernel.Pdf.PdfDocument pdfDoc = new iText.Kernel.Pdf.PdfDocument(pdfReader);
int numberOfPages = pdfDoc.GetNumberOfPages();
int z = 0;
for (int i = 1; i <= numberOfPages; i++)
{
iText.Kernel.Pdf.PdfDictionary page = pdfDoc.GetPage(i).GetPdfObject();
iText.Kernel.Pdf.PdfArray annotArray = page.GetAsArray(iText.Kernel.Pdf.PdfName.Annots);
if (annotArray == null)
{
z++;
continue;
}
int size = annotArray.Size();
for (int x = 0; x < size; x++)
{
iText.Kernel.Pdf.PdfDictionary curAnnot = annotArray.GetAsDictionary(x);
if (curAnnot != null)
{
if (curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData) != null)
{
MessageBox.Show("BSIColumnData: " + curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData).ToString());
}
}
}
}
pdfReader.Close();
}
在Bluebeam Revu中,您可以看到如下:
在itext-rups 5.5.9中,您可以看到如下:
我看到两个错误:
您尝试像这样使用 BSIColumnData 名称:
iText.Kernel.Pdf.PdfName.BSIColumnData
这假设您的自定义名称已经有一个静态
PdfName
成员。但是当然没有,只有 itext 本身使用的标准名称的预定义成员。如果你想使用其他名称,你必须自己创建一个PdfName
实例并使用该实例,例如像这样var BSIColumnData = new iText.Kernel.Pdf.PdfName("BSIColumnData");
您尝试检索该名称的值作为字符串
curAnnot.GetAsString(iText.Kernel.Pdf.PdfName.BSIColumnData)
但从您的 RUPS 屏幕截图可以清楚地看出,该名称的值是一个字符串数组。因此,即使按照第一项
GetAsString(BSIColumnData)
中所述进行更正后,也会 returnnull
。相反做var BSIColumnData = new iText.Kernel.Pdf.PdfName("BSIColumnData"); var array = curAnnot.GetAsArray(BSIColumnData);
选中
访问各自索引处的字符串if (array != null)
后,您现在可以使用array.GetAsString(index)
.