+3

Hướng dẫn tạo file PDF từ Excel bằng thư viện miễn phí JobConverter

Mở đầu

Trong lập trình Java, việc tạo file PDF là một nhiệm vụ phức tạp và thường đòi hỏi sử dụng các thư viện trả phí như iText, JasperReports. Hoặc nếu không có chi phí thì thường là các thư viên như Apache PDFbox, tuy nhiên thường chất lượng đầu ra của PDF là không tốt , không giai quyết được các vấn đề như vị trí, font-size, hình ảnh... Điều này không chỉ tốn kém tiền bạc, thời gian mà còn đòi hỏi kiến thức chuyên sâu về API của các thư viện này. Để giải quyết vấn đề này, JobConverter ra đời như một công cụ miễn phí giúp bạn dễ dàng tạo file PDF bằng cách chuyển đổi từ file Excel mà không cần phải viết mã phức tạp. Bài viết này sẽ hướng dẫn bạn cách sử dụng JobConverter để chuyển đổi file Excel sang PDF một cách hiệu quả và dễ dàng.

Chi tiết

1. Sử dụng Apache POI để tạo hoặc chỉnh sửa file Excel

Trước khi chuyển đổi sang PDF, bạn cần có file Excel, Nếu như chưa có sẵn file Excel bạn có thể tạo nó bằng Apache POI (một thư viện miễn phí của Apache). Apache POI là một thư viện Java mạnh mẽ và linh hoạt, cho phép bạn thao tác với các file Excel. Để sử dụng Apache POI, bạn cần hiểu rõ các API của nó. Dưới đây là một ví dụ cơ bản:

Ví dụ tạo một file excel mới:

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.FileOutputStream;
import java.io.IOException;

public class ExcelCreator {

    public static void main(String[] args) {
        Workbook workbook = new XSSFWorkbook();
        Sheet sheet = workbook.createSheet("Data Sheet");

        Row header = sheet.createRow(0);
        header.createCell(0).setCellValue("ID");
        header.createCell(1).setCellValue("Name");
        header.createCell(2).setCellValue("Age");

        Row row1 = sheet.createRow(1);
        row1.createCell(0).setCellValue(1);
        row1.createCell(1).setCellValue("John Doe");
        row1.createCell(2).setCellValue(30);

        try (FileOutputStream fileOut = new FileOutputStream("example.xlsx")) {
            workbook.write(fileOut);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

Hoặc gán data cho một file excel có sẵn, chúng ta có thể hiểu file excel này như một template, việc của bạn là chỉ cần gán data từ java vào

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

public class ExcelTemplateProcessor {

    public static void main(String[] args) {
        // Đường dẫn tới file Excel
        String inputFilePath = "template.xlsx";
        String outputFilePath = "output.xlsx";

        // Dữ liệu cần thay thế
        Map<String, String> data = new HashMap<>();
        data.put("${fullName}", "Nguyễn Văn A");
        data.put("${age}", "30");
        data.put("${address}", "Hà Nội, Việt Nam");

        // Xử lý file Excel
        try {
            FileInputStream fis = new FileInputStream(inputFilePath);
            Workbook workbook = new XSSFWorkbook(fis);

            // Duyệt qua các sheet trong workbook
            for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
                Sheet sheet = workbook.getSheetAt(i);

                // Duyệt qua các row trong sheet
                for (Row row : sheet) {
                    // Duyệt qua các cell trong row
                    for (Cell cell : row) {
                        if (cell.getCellType() == CellType.STRING) {
                            String cellValue = cell.getStringCellValue();
                            // Thay thế các key bằng giá trị tương ứng
                            for (Map.Entry<String, String> entry : data.entrySet()) {
                                if (cellValue.contains(entry.getKey())) {
                                    cellValue = cellValue.replace(entry.getKey(), entry.getValue());
                                }
                            }
                            cell.setCellValue(cellValue);
                        }
                    }
                }
            }

            // Ghi workbook ra file mới
            FileOutputStream fos = new FileOutputStream(outputFilePath);
            workbook.write(fos);

            // Đóng các stream
            fos.close();
            workbook.close();
            fis.close();

            System.out.println("File Excel đã được xử lý thành công.");

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

Trên đây chỉ là 2 ví dụ để bạn có thể hình dung, vi vậy tùy vào kinh nghiệm mà bạn có thể code tối ưu và mạnh mẽ hơn.

2. Cài đặt các phần mềm Office để xử lý file xlsx

Sau khi tạo file Excel, bạn cần cài đặt các phần mềm Office có khả năng xử lý file xlsx. Các lựa chọn bao gồm:

  • Microsoft Office: Đây là phần mềm phổ biến và mạnh mẽ nhất. Tuy nhiên nó cần trả phí
  • OpenOffice: Một phần mềm mã nguồn mở miễn phí.
  • LibreOffice: Cũng là một phần mềm mã nguồn mở miễn phí và rất mạnh mẽ. ... và còn nhiều phần mếm khác nữa..

3. Sử dụng JobConverter để chuyển đổi từ Excel sang PDF

JobConverter là công cụ giúp bạn chuyển đổi file Excel sang PDF một cách đơn giản. Điều đặc biệt về JobConverter là nó sử dụng các phần mềm Office đã cài đặt để xử lý và chuyển đổi file, thay vì phải đọc và tạo lại file như các thư viện khác. Điều này giúp đảm bảo chất lượng chuyển đổi gần như tuyệt đối, không bị vỡ font hay layout.

Bạn có thể tải JobConverter và làm theo hướng dẫn sau: Thêm đoạn code sau vào file pom.xml, hoặc nếu như không có file pom.xml thì hãy download các gói jar tương ứng , tham khảo thêm tại : https://github.com/jodconverter/jodconverter

<dependencies>
  <dependency>
    <groupId>org.artofsolving.jodconverter</groupId>
    <artifactId>jodconverter-core</artifactId>
    <version>3.0-beta-4</version>
  </dependency>
</dependencies>

Sau đó có thể convert trực tiếp excel qua pdf thông qua cmd

java -jar jobconverter.jar -input example.xlsx -output example.pdf

Hoặc xử lý trên file java.

import java.io.File;

import org.jodconverter.DocumentConverter;
import org.jodconverter.LocalConverter;
import org.jodconverter.office.LocalOfficeManager;
import org.jodconverter.office.OfficeException;
import org.jodconverter.office.OfficeManager;

public class DocConverter {

    public static void main(String[] args) throws OfficeException {

        OfficeManager officeManager = LocalOfficeManager.make();
        DocumentConverter converter = LocalConverter.make(officeManager);
        try {
            officeManager.start();

            File inputFile = new File("/data/test.xlsx");
            File outputFile = new File("/data/test.pdf");
            // Convert...
            converter.convert(inputFile).to(outputFile).execute();
        } finally {
            officeManager.stop();
        }
    }
}

Lưu ý: mặc định OfficeManager sẽ tự nhận phần mêm Office (default) mà bạn đã cài, tuy nhiên trong trường hợp không nhận hoặc khi bạn cài nhiều phần mêm Office trên cùng một máy thì có thể điều hướng thông qua ".officeHome" như bên dưới:

OfficeManager officeManager = LocalOfficeManager.builder()
                .install()
                .officeHome("C:\\Program Files\\LibreOffice")
                .build();

4. Demo

Ví dụ mình có file excel như bên dưới

image.png

Trong file excel, mình có một keyword là ${companyName}, mình sẽ sử dụng ApachePoi để gán data vào file excel này: trong ví dụ này mình đã code toàn bộ xử lý gán data ở method setDataToTemplate, cách làm thì bạn có thể tham khảo ví dụ phía trên nhé hoặc research thêm

image.png

Kết quả sau khi convert sang PDF, bạn sẽ thấy từ layout đến hình ảnh hầu như là tuyệt đối

image.png

Kết luận

JobConverter là một giải pháp hiệu quả và tiết kiệm chi phí cho việc chuyển đổi file Excel sang PDF. Bằng cách tận dụng các phần mềm Office đã cài đặt, nó đảm bảo chất lượng chuyển đổi cao và dễ sử dụng. Hy vọng qua bài viết này, bạn đã nắm được cách sử dụng JobConverter để giải quyết vấn đề chuyển đổi file một cách dễ dàng và hiệu quả. Hãy thử nghiệm và tận hưởng sự tiện lợi mà JobConverter mang lại!


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí