目前看起来只能提前编辑好一堆样式参数,然后根据不同文件的不同表格区域等等,映射到对应样式。很麻烦。
找了3个小时解决方案,没有正常好用的。。
最后自己猜测+试验出来了。
有几个需要注意的地方,这种解决方案,表格内部参数,尽量不要一个格子有多个变量,尽可能的拆分。
同时单元格中尽量不要主动回车换行。
public static void changeTableMessage(Map<String, String> valueMap, XWPFTable table) {
int count = table.getNumberOfRows();//获取table的行数
for (int i = 0; i < count; i++) {
XWPFTableRow row = table.getRow(i);
List<XWPFTableCell> cells = row.getTableCells();
for (XWPFTableCell cell : cells) {//遍历每行的值并进行替换
if (cell.getText().indexOf("$") == -1) {
continue;
}
for (XWPFParagraph paragraph : cell.getParagraphs()) {
String text = paragraph.getText();
if (StringUtils.isBlank(text)) {
continue;
}
if (text.indexOf("$") == -1) {
continue;
}
List<XWPFRun> runs = paragraph.getRuns();
for (XWPFRun run : runs) {
String value = setWordValue(run.toString(), valueMap);
run.setText(value, 0);
}
}
}
}
}
/**
* 匹配传入信息集合与模板
* @param value 模板需要替换的区域
* @param textMap 传入信息集合
* @return 模板需要替换区域信息集合对应值
*/
public static String setWordValue(String value, Map<String, String> textMap) {
Set<Map.Entry<String, String>> textSets = textMap.entrySet();
for (Map.Entry<String, String> textSet : textSets) {
String key = "${" + textSet.getKey() + "}";
if (value.indexOf(key) != -1) {
value = value.replace(key,textSet.getValue());
}
}
return value;
}