如何使用PDFBox 2.0查找并替换PDF文档中的文本,他们拉动了旧的示例,它的语法不再起作用,因此我在想如果它仍然有可能,最好的方法是去做。谢谢!PDFBox 2.0 RC3 - 查找和替换文本
2
A
回答
3
你可以尝试这样的:
public static PDDocument replaceText(PDDocument document, String searchString, String replacement) throws IOException {
if (Strings.isEmpty(searchString) || Strings.isEmpty(replacement)) {
return document;
}
PDPageTree pages = document.getDocumentCatalog().getPages();
for (PDPage page : pages) {
PDFStreamParser parser = new PDFStreamParser(page);
parser.parse();
List tokens = parser.getTokens();
for (int j = 0; j < tokens.size(); j++) {
Object next = tokens.get(j);
if (next instanceof Operator) {
Operator op = (Operator) next;
//Tj and TJ are the two operators that display strings in a PDF
if (op.getName().equals("Tj")) {
// Tj takes one operator and that is the string to display so lets update that operator
COSString previous = (COSString) tokens.get(j - 1);
String string = previous.getString();
string = string.replaceFirst(searchString, replacement);
previous.setValue(string.getBytes());
} else if (op.getName().equals("TJ")) {
COSArray previous = (COSArray) tokens.get(j - 1);
for (int k = 0; k < previous.size(); k++) {
Object arrElement = previous.getObject(k);
if (arrElement instanceof COSString) {
COSString cosString = (COSString) arrElement;
String string = cosString.getString();
string = StringUtils.replaceOnce(string, searchString, replacement);
cosString.setValue(string.getBytes());
}
}
}
}
}
// now that the tokens are updated we will replace the page content stream.
PDStream updatedStream = new PDStream(document);
OutputStream out = updatedStream.createOutputStream();
ContentStreamWriter tokenWriter = new ContentStreamWriter(out);
tokenWriter.writeTokens(tokens);
page.setContents(updatedStream);
out.close();
}
return document;
}
1
我花在想出了一个解决方案的时间和最终获取的Acrobat DC订阅,这样我可以为文本创建字段作为占位符是更换。在我的情况下,这些字段是用于客户信息和订单详细信息,因此它不是非常复杂的数据,但该文档充满了业务相关条件的页面,并且布局非常复杂。
然后我只是做了这个,这可能适合你。
private void update() throws InvalidPasswordException, IOException {
Map<String, String> map = new HashMap<>();
map.put("fieldname", "value to update");
File template = new File("template.pdf");
PDDocument document = PDDocument.load(template);
List<PDField> fields = document.getDocumentCatalog().getAcroForm().getFields();
for (PDField field : fields) {
for (Map.Entry<String, String> entry : map.entrySet()) {
if (entry.getKey().equals(field.getFullyQualifiedName())) {
field.setValue(entry.getValue());
field.setReadOnly(true);
}
}
}
File out = new File("out.pdf");
document.save(out);
document.close();
}
因人而异
+1
使用AcroForm字段确实是应该如何完成PDF填充。但是你不需要Acrobat来创建字段,你也可以用PDFBox来做到这一点...(虽然没有好的GUI) – mkl
+0
Thx @mkl,我意识到可以使用pdfbox创建字段,但我可以没有弄清楚如何将它们放在文档中的确切位置。 –
相关问题
- 1. 查找和替换文本
- 2. 查找和文本文件替换
- 3. 查找和替换脚本
- 4. 如何查找和替换文本?
- 5. 查找和替换c中的文本#
- 6. Java的查找和替换文本
- 7. 用PHPWord查找和替换文本
- 8. jQuery的查找和替换文本
- 9. PHPStorm - 查找和选择替换文本?
- 10. 使用PDFBox替换PDF文本
- 11. 查找和替换文件
- 12. PDFBOX文本换行
- 13. 查找和替换
- 14. 查找和替换
- 15. 查找和替换
- 16. 查找和替换
- 17. 查找和替换:\”
- 18. 查找并替换文本等文字
- 19. 查找 - 替换文本框和表格中包含的文本
- 20. VB脚本查找和替换Word文档中的文本
- 21. 查找和替换 - Google表格脚本
- 22. 在shell脚本中查找和替换
- 23. 使用记事本查找和替换++
- 24. 批处理脚本查找和替换
- 25. 记事本++查找和替换
- 26. 查找和替换函数的脚本
- 27. 记事本+ +定期查找和替换
- 28. 查找和替换为textWrangler脚本
- 29. 查找和替换空行记事本++
- 30. RegEx查找和替换Y文本和Z文本之间的X文本
那个老例子实际上只有在非常简单的PDF工作并没有改变或者(更糟糕的)损坏更复杂的。 – mkl