spire.doc渲染pdf时富文本处理

简介: spire.doc渲染pdf时富文本处理

不以一眚掩大德。——《左传》

使用spire.doc渲染富文本的话,可以使用Paragraph中的appendHTML()函数去渲染富文本,例如下面

package com.ruben;
import com.spire.doc.Document;
import com.spire.doc.FileFormat;
import com.spire.doc.documents.Paragraph;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Locale;
/**
 * @ClassName: WordDemo
 * @Description: 我还没有写描述
 * @Date: 2021/1/15 0015 20:31
 * *
 * @author: <achao1441470436@gmail.com>
 * @version: 1.0
 * @since: JDK 1.8
 */
public class WordDemo {
    private static final String TARGET_PATH = "D:/file/testReport/pdf/" + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd-HH-mm-ss", Locale.CHINA)) + ".pdf";
    public static void main(String[] args) {
        Document doc = new Document();
        Paragraph para = doc.addSection().addParagraph();
        para.appendHTML("阿超-0-{0-[0-(阿超-");
        doc.saveToFile(TARGET_PATH, FileFormat.PDF);
    }
}

执行后我们打开生成的文件

但我们发现,这里的短横线一上一下的,并没有对齐以至于影响了美观

我们可以给它指定一个字体,例如加上标签

package com.ruben;
import com.spire.doc.Document;
import com.spire.doc.FileFormat;
import com.spire.doc.documents.Paragraph;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Locale;
/**
 * @ClassName: WordDemo
 * @Description: 我还没有写描述
 * @Date: 2021/1/15 0015 20:31
 * *
 * @author: <achao1441470436@gmail.com>
 * @version: 1.0
 * @since: JDK 1.8
 */
public class WordDemo {
    private static final String TARGET_PATH = "D:/file/testReport/pdf/" + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd-HH-mm-ss", Locale.CHINA)) + ".pdf";
    public static void main(String[] args) {
        Document doc = new Document();
        Paragraph para = doc.addSection().addParagraph();
        para.appendHTML("<font face='宋体'>阿超-0-{0-[0-(阿超-</font>");
        doc.saveToFile(TARGET_PATH, FileFormat.PDF);
    }
}

然后我们再执行发现刚才的横线整齐了

当然如果是非富文本,例如appendText

Document doc = new Document();
Paragraph para = doc.addSection().addParagraph();
para.appendText("阿超-0-{0-[0-(阿超-");
doc.saveToFile(TARGET_PATH, FileFormat.PDF);

我们同样可以给它加上字体,如下

Document doc = new Document();
Paragraph para = doc.addSection().addParagraph();
TextRange text = para.appendText("阿超-0-{0-[0-(阿超-");
CharacterFormat format = text.getCharacterFormat();
format.setFontName("宋体");
doc.saveToFile(TARGET_PATH, FileFormat.PDF);

这样就不会出现这种情况了

相关文章
|
6月前
|
前端开发 JavaScript API
技术笔记:vue+pdfh5实现将pdf渲染到页面上
技术笔记:vue+pdfh5实现将pdf渲染到页面上
|
7月前
|
XML Java Android开发
Android App开发手机阅读中PDF文件渲染器的讲解及使用(附源码 简单易懂)
Android App开发手机阅读中PDF文件渲染器的讲解及使用(附源码 简单易懂)
272 0
|
前端开发
Freemarker动态模板渲染&flyingsaucer将html转PDF(多页固定头尾)
Freemarker动态模板渲染&flyingsaucer将html转PDF(多页固定头尾)
|
数据安全/隐私保护 iOS开发 开发者
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建(二)
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建
341 0
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建(二)
|
数据安全/隐私保护 iOS开发 开发者
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建(一)
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建
479 0
iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建(一)
|
10天前
|
人工智能 文字识别 数据挖掘
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
MarkItDown 是微软开源的多功能文档转换工具,支持将 PDF、PPT、Word、Excel、图像、音频等多种格式的文件转换为 Markdown 格式,具备 OCR 文字识别、语音转文字和元数据提取等功能。
78 9
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
|
13天前
|
JavaScript
jquery图片和pdf文件预览插件
EZView.js是一款jquery图片和pdf文件预览插件。EZView.js可以为图片和pdf格式文件生成在线预览效果。支持的文件格式有pdf、jpg、 png、jpeg、gif。
44 16
|
2月前
|
Java Apache Maven
将word文档转换成pdf文件方法
在Java中,将Word文档转换为PDF文件可采用多种方法:1) 使用Apache POI和iText库,适合处理基本转换需求;2) Aspose.Words for Java,提供更高级的功能和性能;3) 利用LibreOffice命令行工具,适用于需要开源解决方案的场景。每种方法都有其适用范围,可根据具体需求选择。
|
2月前
|
Java Apache Maven
Java将word文档转换成pdf文件的方法?
【10月更文挑战第13天】Java将word文档转换成pdf文件的方法?
574 1
|
2月前
|
索引 Python
PDF文件页面提取操作小指南
PDF文件页面提取操作小指南
102 4