Integrate PDF Tables with Data Sources in Java
Contents
[
Hide
]
The Java example builds PDF tables from CSV data without relying on external dataframe libraries.
Build a table from CSV rows
Use this example when selected CSV columns should be transformed into a styled PDF table.
- Create a Table and configure its borders.
- Detect the required column indexes from the CSV header row.
- Add the header row and the requested number of data rows, then return the table.
public static Table createTableFromCsv(List<String[]> rows, int maxRows) {
Table table = new Table();
table.setBorder(new BorderInfo(BorderSide.All, 1, Color.getLightGray()));
table.setDefaultCellBorder(new BorderInfo(BorderSide.Bottom, 1, Color.getLightGray()));
String[] header = rows.get(0);
int[] selectedColumns = findColumns(header, "city", "country", "population", "iso3");
Row headerRow = table.getRows().add();
headerRow.setRowBroken(false);
for (int columnIndex : selectedColumns) {
Cell cell = headerRow.getCells().add(header[columnIndex]);
cell.setBackgroundColor(Color.getLightGray());
}
int limit = Math.min(maxRows, rows.size() - 1);
for (int rowIndex = 1; rowIndex <= limit; rowIndex++) {
Row row = table.getRows().add();
String[] rowData = rows.get(rowIndex);
for (int columnIndex : selectedColumns) {
row.getCells().add(columnIndex < rowData.length ? rowData[columnIndex] : "");
}
}
return table;
}
Create a PDF from CSV data
Use this example when CSV input should be rendered as a PDF table document.
- Read the CSV rows from the input file.
- Preview a subset of the parsed rows in the console.
- Create a PDF Document, add the generated table, and save the output file.
public static void createPdfFromCsv(Path inputFile, Path outputFile, int maxRows) throws Exception {
List<String[]> rows = readCsv(inputFile);
for (int i = 0; i < Math.min(20, rows.size()); i++) {
System.out.println(String.join(" | ", rows.get(i)));
}
try (Document document = new Document()) {
Page page = document.getPages().add();
page.getParagraphs().add(createTableFromCsv(rows, maxRows));
document.save(outputFile.toString());
}
}
Find CSV column indexes by name
Use this helper when specific named columns must be located in the CSV header row.
- Iterate through the requested column names.
- Search the header row for matching indexes.
- Return the collected column positions.
private static int[] findColumns(String[] header, String... names) {
int[] indexes = new int[names.length];
for (int i = 0; i < names.length; i++) {
indexes[i] = 0;
for (int j = 0; j < header.length; j++) {
if (names[i].equals(header[j])) {
indexes[i] = j;
break;
}
}
}
return indexes;
}
Read CSV rows from a file
Use this helper when the CSV source should be loaded into memory before table generation.
- Read all lines from the input file.
- Split each line with the CSV parser helper.
- Return the collected row values.
private static List<String[]> readCsv(Path inputFile) throws Exception {
List<String[]> rows = new ArrayList<>();
for (String line : Files.readAllLines(inputFile)) {
rows.add(splitCsvLine(line));
}
return rows;
}
Split one CSV line into values
Use this helper when a CSV row may contain quoted values and escaped quote characters.
- Iterate through the characters in the line.
- Track whether the parser is currently inside quoted text.
- Build the final value list and return it as an array.
private static String[] splitCsvLine(String line) {
List<String> values = new ArrayList<>();
StringBuilder current = new StringBuilder();
boolean inQuotes = false;
for (int i = 0; i < line.length(); i++) {
char ch = line.charAt(i);
if (ch == '"') {
if (inQuotes && i + 1 < line.length() && line.charAt(i + 1) == '"') {
current.append('"');
i++;
} else {
inQuotes = !inQuotes;
}
} else if (ch == ',' && !inQuotes) {
values.add(current.toString());
current.setLength(0);
} else {
current.append(ch);
}
}
values.add(current.toString());
return values.toArray(String[]::new);
}