使用golang生成pdf文档可通过go-pdf库实现,其步骤为:安装库、初始化配置、添加页面、设置字体、写入内容及输出文件。具体流程包括:1. 运行go get github.com/signintech/gopdf安装库;2. 初始化并设置页面大小为a4;3. 添加页面并通过addttffont加载中文字体避免乱码;4. 使用setfont设置字体和字号,通过cell写入文本;5. 插入图片用image方法指定路径和坐标;6. 表格效果通过moveto和lineto画线结合cell模拟实现;7. 多页处理调用addpage,页边距控制用setx或sety设定坐标,最终通过writepdf保存文件。

用Golang生成PDF文档,其实并不复杂。go-pdf 是一个轻量级的库,适合用来生成简单的 PDF 文件,比如发票、报告或者导出内容为 PDF 格式。

安装 go-pdf 库
在开始之前,你需要先安装 go-pdf 包。打开终端运行:
go get github.com/signintech/gopdf
这个包不需要额外依赖,直接引入就可以用了。
立即学习“go语言免费学习笔记(深入)”;

创建一个基础 PDF 文件
使用 go-pdf 创建 PDF 的流程比较简单,主要步骤包括初始化、设置字体、添加页面、写入内容等。
示例代码如下:

package main
import (
"github.com/signintech/gopdf"
)
func main() {
pdf := gopdf.GoPdf{}
pdf.Start(gopdf.Config{PageSize: *gopdf.PageSizeA4}) // 设置 A4 纸张大小
pdf.AddPage() // 添加一页
err := pdf.AddTTFFont("wqy", "WenQuanYiZenHei.ttf") // 添加中文字体
if err != nil {
panic(err)
}
pdf.SetFont("wqy", "", 14) // 设置字体和字号
pdf.Cell(nil, "你好,世界!") // 写入文本
pdf.WritePdf("hello.pdf") // 输出到文件
}几点需要注意:
- 如果你用的是中文,必须加载中文字体(如文泉驿正黑),否则会乱码。
-
Cell方法用于写入一段文本,还可以设置宽度、高度等参数。 - 页面尺寸可以是 A4、Letter 或者自定义。
添加图片和表格内容
除了文本,你可能还需要插入图片或者做一些简单的表格样式。
插入图片
pdf.Image("logo.png", 50, 50, nil) // 在指定位置插入图片支持 PNG 和 JPEG 格式,注意路径要正确。
表格效果模拟
go-pdf 没有内置的表格组件,但可以通过画线 + 文本组合来实现简单的表格:
- 使用
MoveTo和LineTo方法绘制线条 - 每个单元格用
Cell填充内容
例如:
pdf.MoveTo(50, 100) pdf.LineTo(200, 100) pdf.Stroke()
这样可以画一条横线,配合坐标控制,就能做出表格的边框了。
处理页边距与多页内容
如果你的内容较多,需要分页处理,可以在合适的位置调用 AddPage() 方法。
页边距方面,你可以自己设定起始坐标。比如从左边距 50 开始写内容:
pdf.SetX(50)
或者设置当前行的 Y 坐标:
pdf.SetY(150)
也可以封装一个函数,自动计算下一行的位置。
基本上就这些。go-pdf 功能不算特别强大,但胜在简单易用,适合做数据导出类的 PDF 生成任务。如果需要更复杂的布局,可能要考虑其他库或工具链,比如 wkhtmltopdf 结合 HTML 渲染。











