Golang PDF 문서 생성하는 GoFPDF 라이브러리 알아보기

오늘은 Golang으로 구현된 PDF 문서를 고수준의 방식의 생성기로 생성할 수 있는 GoFPDF 라이브러리를 알아보려 합니다.

GoFPDF 설치

우선 Golang의 환경을 구성하기 위해 https://golang.org/dl/ 에서 윈도우, 리눅스, 맥에서 설치 프로그램을 내려받을 수 있습니다.

맥에서 brew로 쉽게 설치할 수 있습니다.

brew install go

우분투에서도 apt로 쉽게 설치할 수 있습니다.

sudo apt-get install golang-go

맥에서 Golang의 버전을 올리려면 brew를 이용합니다.

brew upgrade go

우분투에서도 Golang의 버전을 올리려면 backports 저장소를 등록하고 apt를 이용합니다.

sudo add-apt-repository ppa:longsleep/golang-backports
sudo apt-get update
sudo apt-get install golang-go

go get으로 GoFPDF 패키지를 설치합니다.

go get github.com/jung-kurt/gofpdf

홈의 go 폴더에 GoFPDF 소스코드와 패키지 파일이 생성됩니다.

예제

package main

해당 소스코드를 실행 파일로 인식하게 해주도록 main이라고 선언합니다.

import "github.com/jung-kurt/gofpdf"

gofpdf를 가져옵니다.

func main() {
	pdf := gofpdf.New("portrait", "mm", "A4", "")

새로운 Fpdf 객체를 만듭니다.

	pdf.AddPage()

Fpdf 객체에서 문서의 페이지를 추가합니다.

	pdf.SetAuthor("author", true)

Fpdf 객체에서 문서의 작성자를 정의하여 파일 정보에서 작성자를 볼 수 있게 합니다.

	pdf.SetTitle("title", true)

Fpdf 객체에서 문서의 제목을 정의하여 파일 정보에서 제목을 볼 수 있게 합니다.

	pdf.SetFont("Arial", "B", 16)

Fpdf 객체에서 문서의 폰트를 설정합니다.

	pdf.Cell(50, 20, "Hello, world!")

Fpdf 객체에서 문서의 셀을 생성하고 문자열을 기록합니다.

	err := pdf.OutputFileAndClose("test.pdf")
	if err != nil {
		panic(err)
	}
}

test.pdf 파일로 저장하고 객체를 닫습니다.

Written on October 17, 2019