是否可以附加2个富文本字符串?

Sai*_*S M 2 java html5 apache-poi

我需要使用Apache POI附加到Java中的2个HSSFRichTextStrings.我怎样才能做到这一点?
我正在做的是我正在获取已存在于单元格中的富文本字符串,并且我正在尝试向其附加一个额外的富文本字符串并将其写回单元格.
请告诉我怎么做.

rge*_*man 6

可以追加两个HSSFRichTextStrings,但你必须自己完成大部分工作.您需要在以下方面利用以下方法HSSFRichTextString:

首先,创建一个小类来存储格式化运行统计信息:

public class FormattingRun {
    private int beginIdx;
    private int length;
    private short fontIdx;
    public FormattingRun(int beginIdx, int length, short fontIdx) {
        this.beginIdx = beginIdx;
        this.length = length;
        this.fontIdx = fontIdx;
    }
    public int getBegin() { return beginIdx; }
    public int getLength() { return length; }
    public short getFontIndex { return fontIdx; }
}
Run Code Online (Sandbox Code Playgroud)

接下来,收集两个字符串中每个字符串的所有格式化运行统计信息.您必须自己走动字符串以确定每个格式化运行的持续时间.

List<FormattingRun> formattingRuns = new ArrayList<FormattingRun>();
int numFormattingRuns = richTextString.numFormattingRuns();
for (int fmtIdx = 0; fmtIdx < numFormattingRuns; fmtIdx)
{
    int begin = richTextString.getIndexOfFormattingRun(fmtIdx);
    short fontIndex = richTextString.getFontOfFormattingRun(fmtIdx);

    // Walk the string to determine the length of the formatting run.
    int length = 0;
    for (int j = begin; j < richTextString.length(); j++)
    {
        short currFontIndex = richTextString.getFontAtIndex(j);
        if (currFontIndex == fontIndex)
            length++;
        else
            break;
    }
    formattingRuns.add(new FormattingRun(begin, length, fontIndex));
}
Run Code Online (Sandbox Code Playgroud)

接下来,String自己连接这两个值并创建结果HSSFRichTextString.

HSSFRichTextString result = new HSSFRichTextString(
     richTextString1.getString() + richTextString2.getString());
Run Code Online (Sandbox Code Playgroud)

最后,应用两组格式化运行,第二组运行偏移第一个字符串的长度.

for (FormattingRun run1 : formattingRuns1)
{
    int begin = run1.getBegin();
    int end = begin + run1.getLength();
    short fontIdx = run1.getFontIndex();
    result.applyFont(begin, end, fontIdx);
}
for (FormattingRun run2 : formattingRuns2)
{
    // offset by string length 1
    int begin = run2.getBegin() + richTextString1.length();
    int end = begin + run2.getLength();
    short fontIdx = run2.getFontIndex();
    result.applyFont(begin, end, fontIdx);
}
Run Code Online (Sandbox Code Playgroud)

这应该用于连接HSSFRichTextStrings.

如果你想XSSFRichTextStrings在.xlsx文件中找到连接,那么这个过程非常相似.一个区别是XSSFRichTextString#getFontOfFormattingRun将返回一个XSSFFont而不是short字体索引.这没关系,因为调用applyFontXSSFRichTextString花费的XSSFFont反正.另一个区别是,如果没有为格式化运行应用任何字体,则getFontOfFormattingRun可能会抛出a NullPointerException,这种情况发生时,如果没有应用的字体不同于已经存在CellStyle的整个字体Cell.